Python 的双下划线之谜:隐私的虚假承诺
尽管存在双下划线,但令人惊讶的是,Python 的“私有”方法是不完全私人。这种明显的悖论源于Python独特的封装方法。
当双下划线作为方法或变量名称的前缀时,Python将其解释为更改名称的指示符。它不使用原始名称,而是连接下划线、类名和原始名称。例如, __myPrivateMethod 变为 _MyClass__myPrivateMethod。
这种名称加扰技术有一个目的:它可以防止子类意外覆盖从其超类继承的私有方法和属性。考虑这个例子:
class Foo(object): def __init__(self): self.__baz = 42 def foo(self): print self.__baz
如果子类 Bar 定义了一个与其超类的私有成员同名的成员,Python 的名称置乱机制可确保它们保持不同并避免潜在的冲突。
但是,这种技术并不能阻止从类外部故意访问私有成员。如下例所示,可以使用更改后的名称直接访问重命名的私有成员:
x = Foo() print x._Foo__baz # Output: 42
因此,虽然 Python 的双下划线约定造成了隐私的错觉,但它最终是一种弱封装形式。它可以防止子类意外覆盖方法,但无法防止来自外部实体的有意访问。
以上是Python 的双下划线表示法是数据隐私的真正形式吗?的详细内容。更多信息请关注PHP中文网其他相关文章!