封装定义:
-
封装是面向对象的三大特性之一(封装,继承,多态)
-
封装指的是隐藏对象中一些不希望被外界所访问到的属性或方法
如何隐藏一个对象中的属性?
- 将对象的属性名,修改为一个外部不知道的名字,防君子不防小人
如何获取(修改)对象中的属性?
-
需要提供一个getter和setter方法是外部可以访问到属性
-
getter获取对象中的指定属性(get_属性名)
-
setter用来设置对象的指定属性(set_属性名)
使用封装,缺失增加了类的定义的复杂程度,但是它也确保了数据的安全性
-
隐藏了属性名,使得调用者无法随意的修改对象中的属性
-
增加了getter和setter放到,很好的控制的属性是否是只读的,如果希望属性是只读的,则可以直接去掉setter方法,如果希望属性不能被外部访问,则可以直接去掉getter方法
-
使用setter方法设置属性,可以增加数据的验证,确保数据是正确的
-
使用getter方法获取属性,使用setter方法设置属性可以在读取属性和修改属性的同时做一些其他的处理
例子
class Dog:
... def __init__(self,name,age):
... self.hidden_name = name
... self.hidden_age = age
... def say_hello(self):
... print('大家好,我是%s'%self.hidden_name)
... def get_name(self):
... print('用户读取了属性')
... return self.hidden_name
... def set_name(self,name):
... print('用户修改了属性')
... self.hidden_name = name
... def get_age(self):
... print('用户访问了年龄')
... return self.hidden_age
... def set_age(self,age):
... print('用户修改了年龄')
... if age > 0:
... self.hidden_age = age
...
#下面是交互测试例子
d = Dog('哈哈哈',5)
d.say_hello()
大家好,我是哈哈哈
d.get_name()
用户读取了属性
'哈哈哈'
d.get_age()
用户访问了年龄
5
d.set_name('xiaoyuer')
用户修改了属性
d.get_name()
用户读取了属性
'xiaoyuer'
d.set_age(6)
用户修改了年龄
d.get_age()
用户访问了年龄
6
d.hidden_age
6
d.hidden_name
'xiaoyuer'
隐藏类中的属性:
-
使用__开头的属性,实际上依然可以在外部访问,所以这种方式我们一般不用,使用 对象._类名__变量 进行访问
-
一般我们会将一些私有属性(不希望被外部访问的属性)以_开头
-
一般情况下,使用_开头的属性都是私有属性,没有特殊需要不要修改私有属性
class Person:
... def __init__(self,name):
... self.__name = name
... def get_name(self):
... return self.__name
... def set_name(self,name):
... self.__name = name
...
p = Person('sunwukong')
p.get_name()
'sunwukong'
p.__name
Traceback (most recent call last):
File "<input>", line 1, in <module>
AttributeError: 'Person' object has no attribute '__name'
print(p._Person__name)
sunwukong
装饰器Property
property属性:
- property装饰器,用来将一个get方法,转换成为对象的属性
- 添加property装饰器以后,我们就可以像调用属性一样使用get方法
- 使用property装饰器的方法,必须和属性名是一样的
例子
class Person:
def __init__(self,name,age):
self._name = name
self._age = age
#property装饰器,用来将一个get方法,转换成为对象的属性
#添加property装饰器以后,我们就可以像调用属性一样使用get方法
#使用property装饰器的方法,必须和属性名是一样的
#getter方法
@property
def name(self):
print('get方法执行了')
return self._name
@name.setter
def name(self,name):
print('setter方法调用了')
self._name = name
@property
def age(self):
print('getter方法调用')
return self._age
@age.setter
def age(self,age):
self._age = age
p = Person('唐僧',28)
p.name
get方法执行了
'唐僧'
p.name = '小鹏'
setter方法调用了
p.age
getter方法调用
28
p.age = 90
p.age
getter方法调用
90