Python“私有”名称修改和实例与类属性

前端之家收集整理的这篇文章主要介绍了Python“私有”名称修改和实例与类属性前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在编写一个需要访问私有变量的装饰器,并发现了这种差异.有谁能解释一下?

(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年起至少保持不变.

是的,类属性和实例属性是正确的术语.类属性始终是共享的,但是对实例上的属性的赋值会分配给实例.变换列表或其他可变对象与属性赋值不同.

猜你在找的Python相关文章