公有和私有
一般面向对象的编程语言都会区分公有和私有的数据类型,像C++和Java,它们使用 public 和 private 关键字,用于声明数据是公有的还是私有的,但在 Python 中并没有用类似的关键字来修饰。
难道 Python 中所有东西都是透明的?也不全是,默认对象的属性和方法都是公开的,可以直接通过点操作符(.)进行访问:
>>> class Person:
name ="小魔女"
>>> p = Person()
>> > p.name
'小魔女'
为了实现类似私有变量的特征,Python内部采用了一种叫NameMangling(名字改编)的技术,在Python中定义私有变量只需要在变量名或函数名前加上“_ _”两个下划线,那么这个函数或变量就会成为私有的了:
>>> class Person:
_ _ name ="小魔女"
>>> p = Person ()
>>> p. _ _ name
Traceback (most recent call last):
File "", line 1, in
p. _ _name
AttributeError:’Person' object has no attribute' _ _ name'
这样在外部将变量名“隐藏”起来了,理论上如果要访问,就需要从内部进行:
>>> class Person:
def _ _ init _ _ (self, name):
self. _ _ name = name
def getName(self):
return self._ _ name
>>> p = Person("小魔女")
>>>P. _ _ name
Traceback (most recent call last):
File "”, line 1, in
p. _ _ name
AttributeError:'Person'object has no attribute ’_ _ name '
>>>p.getName()
'小魔女'
但是认真琢磨一下这个技术的名字:name mangling(名字改编),那就不难发现其实 Python 只是动了一下手脚,把两个下画线开头的变量进行了改名而已。实际上在外部使用“_类名__ 变量名”即可访问两个下划线开头的私有变量了:
>>> p._Person_ _name
'小魔女'
注意:
Python 目前的私有机制其实是伤私有,Python的类是没有权限控制的,所有变量都是可以被外部调用的。最后这部分有些读者(尤其是没有接触过面向对象编程的读者) 可能看不懂,想不明白有什么用?没事,先放着,学完下一节的继承机制就会那然开朗了。
欢迎留言点赞关注
我们一起分享AI学习与发展的干货
如转载,请后台留言,遵守转载规范