Python“私有”名称修改和实例与类属性
发布时间:2021-01-11 16:13:23 所属栏目:Python 来源:互联网
导读:我正在编写一个需要访问私有变量的装饰器,并发现了这种差异.有谁能解释一下? (Python 2.5) 对于在类中定义的属性,命名修改可以正常工作: class Tester(object):... __foo = hi t = Tester() t._Tester__foohi 实例属性不起作用(这是我们应该这样做的方式吗
我正在编写一个需要访问私有变量的装饰器,并发现了这种差异.有谁能解释一下? (Python 2.5) 对于在类中定义的属性,命名修改可以正常工作: >>> class Tester(object): ... __foo = "hi" >>> t = Tester() >>> t._Tester__foo 'hi' 实例属性不起作用(这是我们应该这样做的方式吗?) >>> class Tester(object): ... def __init__(self): ... self.__foo = "hi" >>> t = Tester() >>> t._Tester__foo AttributeError: 'Tester' object has no attribute '_Tester__foo' 附: “class attribute”对于这些是正确的词吗?它们不是静态的,但如果你将其中一个列表或其他可变类型,它就是共享的…… 更新 事实上,第二个例子也可以正常工作.这是一个硬件问题(重启帮助). 解决方法这实际上是不正确的.名称修改发生在课堂创建时;任何引用受损名称的函数也会被调整. 我无法重现您的示例,至少在Mac上的Python版本2.4,2.5,2.6,3.1和3.2中没有: >>> class Tester(object): ... def __init__(self): ... self.__foo = "hi" ... >>> Tester()._Tester__foo 'hi' >>> Tester().__foo Traceback (most recent call last): File "<stdin>",line 1,in <module> AttributeError: 'Tester' object has no attribute '__foo' 如果您反汇编函数字节码,您可以看到名称已被损坏: >>> import dis >>> dis.dis(Tester.__init__) 3 0 LOAD_CONST 1 ('hi') 3 LOAD_FAST 0 (self) 6 STORE_ATTR 1 (_Tester__foo) 9 LOAD_CONST 0 (None) 12 RETURN_VALUE 我检查了compiler source并且所有名称都通过mangler运行,这个代码路径自2002年起至少保持不变. 是的,类属性和实例属性是正确的术语.类属性始终是共享的,但是对实例上的属性的赋值会分配给实例.变换列表或其他可变对象与属性赋值不同. (编辑:甘南站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |