Python的面向对象没有严格的定义私有,公有,保护;但是有一定的命名风格来显示当前成员变量,成员函数的属性。只是一种约定俗成的规矩,Python的函数和变量没有什么私有的概念。
总结:Python中常常使用一条单下划线开头命名一些工具函数,中间变量等等,提醒程序员没必要或不要引用当前变量,函数。
1. 类中的变量
1. 1 双下划线开头
双下划线开头,当前变量会被Python替换为_className__variableName,在类外,你无法直接访问原有的变量名,只能访问被Python替换的变量名。
# -*- coding: utf-8 -*-
class Student:
def __init__(self, name):
self.__name = name
print(self.__name)
if __name__ == "__main__":
obj = Student("ZKJ")
# 下一句正确, 下下句不正确
print(obj._Student__name)
print(obj.__name)
1.2 单下划线开头
1)单下划线是为了简化双下划线,因为双下划线如果不换名称在类外访问是做不到的。而单下划线起到一个提示作用,告诉你这个变量没必要在类外访问。(比如一些中间变量,工具函数等)
# -*- coding: utf-8 -*-
class Student:
def __init__(self, name):
self._name = name
print(self._name)
if __name__ == "__main__":
obj = Student("ZKJ")
# 正确, _仅仅起提示作用
print(obj._name)
2)单下划线开头的变量不会被from module import *导入,防止命名冲突;但是import module可以访问。一般不建议使用from module import *,因此"_"的这个功能使用的少。
# -*- coding: utf-8 -*-
# file: stu.py
_age = 23
# -*- coding: utf-8 -*-
# file: person.py
from stu import *
# 错误
print(_A)
# -*- coding: utf-8 -*-
# file: person.py
import stu
# 正确
print(stu._age)
从上面的代码可以看出"_"是为了防止命名冲突。
1.3 左右均有两根下划线
代表系统函数比如__init__,用户不能自定义。
2. 类中的函数
函数的使用和变量一样。
参考文献
http://www.cnblogs.com/wanpython/archive/2013/05/23/3095534.html
http://www.cnblogs.com/wangshuyi/p/6096362.html