我对python中的属性有点困惑。考虑以下代码
class A:
@property
def N(self):
print("A getter")
return self._N
@N.setter
def N(self,v):
print("A setter")
self._N = v
def __init__(self):
self._N = 1
class B:
@property
def N(self):
print("B getter")
return self.a.N
@N.setter
def N(self,v):
print("B setter")
self.a.N = v
def __init__(self):
self.a = A()
if __name__ == '__main__':
b=B()
b.N = 2
print(b.N, b.a.N)
b.N = 3
print(b.N, b.a.N)
B应该类似于a的包装器。它使用getter和setter将a的属性映射到自身上(当然也可以通过继承来实现)。问题是,它在python2.6中根本不能像预期的那样工作,而在python3:中却可以
> python2 test.py
A getter
(2, 1)
A getter
(3, 1)
> python3 test.py
B setter
A setter
B getter
A getter
A getter
2 2
B setter
A setter
B getter
A getter
A getter
3 3
我做错了什么吗?问题到底出在哪里?
A和B必须是Python2.x中的新型类。
property([fget[, fset[, fdel[, doc]]]])
返回新型类(从对象派生的类)的属性属性。
因此,如果您将从object
导出
class A(object):
...
class B(object):
...
您的代码将按预期工作。