Python学习札记(三十二) 面向对象编程 Object Oriented Program 3

参考:访问限制

NOTE

1.eg.

#!/usr/bin/env python3

class Student(object):
	"""docstring for Student"""
	def __init__(self, name, age, city):
		self.__name = name
		self.__age = age
		self.__city = city

	def print_info(self):
		print(self.__name, self.__age, self.__city)

	def changeinfo(self, option, value):
		if option == 'name':
			self.__name = value
		elif option == 'age':
			self.__age = value
		elif option == 'city':
			self.__city = value

def main():
	student = Student('Chen', 20, 'FuZhou')
	student.print_info()
	cg = int(input())
	if cg == 0:
		student.changeinfo('name', input())
	elif cg == 1:
		student.changeinfo('age', int(input()))
	elif cg == 2:
		student.changeinfo('city', input())
	student.print_info()

if __name__ == '__main__':
	main()
sh-3.2# ./oop2.py 
Chen 20 FuZhou
0
Wang
Wang 20 FuZhou

sh-3.2# ./oop2.py 
Chen 20 FuZhou
1
21
Chen 21 FuZhou

sh-3.2# ./oop2.py 
Chen 20 FuZhou
2
HangZhou
Chen 20 HangZhou

2.在Class内部,可以有属性和方法,而外部代码可以通过直接调用实例变量的方法来操作数据,这样,就隐藏了内部的复杂逻辑。但是,如果要确保外部代码不能随意修改对象内部的状态,就需要有private属性的存在。

如果要让内部属性不被外部访问,可以把属性的名称前加上两个下划线__,在Python中,实例的变量名如果以__开头,就变成了一个私有变量(private),只有内部可以访问,外部不能访问。

如:

def __init__(self, name, age, city):
    self.__name = name
    self.__age = age
    self.__city = city

其中__name,__age,__city是私有变量,无法被外界访问,需要借助类提供的方法来访问:

def print_info(self):
    print(self.__name, self.__age, self.__city)

这样就确保了外部代码不能随意修改对象内部的状态,这样通过访问限制的保护,代码更加健壮。

3.需要注意的是与__xxx__变量的区别,它在Python中是特殊变量,也就是以双下划线开头,并且以双下划线结尾的,允许外部直接访问。

4.原理:不能直接访问__name是因为Python解释器对外把__name变量改成了_Student__name

也就是:

_[类名]__[属性名]

外界也可以通过这样的方法引用它:

print(student._Student__name)

但是强烈建议你不要这么干,因为不同版本的Python解释器可能会把__name改成不同的变量名。

也就是说,不同的解释器会解释成不一样的结果。

5.Python本身没有任何机制阻止你干坏事,一切全靠自觉。有点培养代码洁癖的意思哈哈。

6.错误写法:

	stu_a = Student('antonin', 20, 'SA')
	stu_a.__name = 'Chen'
	stu_a.print_info()

看上去像是从外部修改了__name属性,但是实际上是为这个对象新加入了一个属性__name,其本身的stu_a._Student__name 还是不变:

sh-3.2# ./oop3.py 
antonin 20 SA

2017/2/25

posted @ 2017-02-25 16:50  Wasdns  阅读(210)  评论(0编辑  收藏  举报