除了名字以外,这些类之间有什么不同吗?
class WithClass ():
def __init__(self):
self.value = "Bob"
def my_func(self):
print(self.value)
class WithoutClass ():
value = "Bob"
def my_func(self):
print(self.value)
如果我使用或不使用__init__方法来声明变量值,会有任何区别吗?
我主要担心的是,我只会以一种方式使用它,而这会给我带来更多的问题。
class foo(object):
mStatic = 12
def __init__(self):
self.x = "OBj"
考虑到foo根本无法访问x(事实)
现在的冲突是通过实例或直接通过类访问mStatic。
从Python内存管理的角度来考虑:
12的值在内存中,名称mStatic(可以从类中访问)
指向它。
c1, c2 = foo(), foo()
这一行创建了两个实例,其中包括指向值12的名称mStatic(到目前为止)。
foo.mStatic = 99
这使得mStatic name指向内存中值为99的新位置。
因为(婴儿)c1 c2仍然在(爸爸)foo后面,所以它们有相同的名字(c1。mStatic & c2。mStatic)指向相同的新值。
但一旦每个宝宝决定独自走路,情况就不同了:
c1.mStatic ="c1 Control"
c2.mStatic ="c2 Control"
从现在到以后,该家族中的每一个(c1,c2,foo)都有它的mStatica指向不同的值。
[请尝试使用id()函数为所有(c1,c2,foo)在不同的状态,我们谈到,我认为这将使事情更好]
这就是我们真实的生活。儿子从父亲那里继承了一些信仰,这些信仰在儿子决定改变之前仍然与父亲的信仰相同。
希望对大家有所帮助
类就像创建对象的蓝图。让我们用建房子来做个比喻。你有房子的蓝图,所以你可以建造房子。你可以在资源允许的情况下建造尽可能多的房子。
在这个比喻中,蓝图是类,房子是类的实例化,创建一个对象。
这些房子有共同的属性,比如有屋顶、客厅等。这就是init方法的作用。它用你想要的属性构造对象(房子)。
让我们假设你有:
`class house:`
`roof = True`
`def __init__(self, color):`
`self.wallcolor = color`
>>创建小金锁的房子:
>> goldlock = house() #() invoke's class house, not function
>> goldlock.roof
>> True
all house's have roofs, now let's define goldlock's wall color to white:
>> goldlock.wallcolor = 'white'
>>goldlock.wallcolor
>> 'white'
如果跟踪类和实例字典,这很容易理解。
class C:
one = 42
def __init__(self,val):
self.two=val
ci=C(50)
print(ci.__dict__)
print(C.__dict__)
结果是这样的:
{'two': 50}
{'__module__': '__main__', 'one': 42, '__init__': <function C.__init__ at 0x00000213069BF6A8>, '__dict__': <attribute '__dict__' of 'C' objects>, '__weakref__': <attribute '__weakref__' of 'C' objects>, '__doc__': None}
注意,我在这里设置了完整的结果,但重要的是,实例ci字典将只是{'two': 50},类字典将有'one': 42键值对在里面。
这是关于特定变量的所有信息。