我对继承中的Python中的变量共享概念感到困惑。
考虑以下代码:
class a(object):
var1 = 0
var2 = {}
def print_var(self):
print(self.var1)
print(self.var2)
class b(a):
@classmethod
def modify_var(cls):
cls.var1 = 1
cls.var2['temp']="something"
o1 = a()
o2 = b()
print("Initial Values")
o1.print_var()
o2.print_var()
print("Changing Values")
o2.modify_var()
print("Print values after change")
o1.print_var()
o2.print_var()
运行上面的代码后,我可以看到字典在子类和父类之间共享,但整数变量没有。
有人能解释一下这一点吗,或者我在这里做错了什么?
以上代码的输出:
Initial Values
0
{}
0
{}
Changing Values
Print values after change
0 # <- this zero should be one according to my understanding
{'temp': 'something'}
1
{'temp': 'something'}
发布于 2018-04-30 20:04:06
通常,您不希望使用可变类变量。类变量通过对象引用共享给类的所有实例。但它不会在继承的类之间共享。
因此,所有a
实例都共享对a.var1
和a.var2
的对象引用。类似地,所有b
实例都共享对b.var1
和b.var2
的对象引用。在创建继承时,b
还会获得对var1
和var2
的引用,但它们不会被共享回a
或a
的任何实例化。
因为您将可变对象用于var2
,所以在继承之后,该对象的引用永远不会更改。因此,您可以修改var2
,所有对它的引用都会修改它,因为对象引用是相同的。
如果您重新分配var2
而不是修改它,您将获得预期的行为。
试试这个:
class a(object):
var1 = 0
var2 = {}
def print_var(self):
print(self.var1, end=', ')
print(self.var2)
class b(a):
@classmethod
def modify_var(cls):
cls.var1 = 1
cls.var2 = {'temp': 'something'} # reassign to a new dict
以下是一些测试:
ob1 = a()
ob2 = b()
o1.print_var()
o2.print_var()
o2.modify_var()
o1.print_var()
o2.print_var()
# prints
0, {}
0, {}
0, {}
1, {'temp': 'something'}
https://stackoverflow.com/questions/50099699
复制相似问题