1.特殊方法
- 在类中可以定义一些特殊方法也称为魔术方法
- 特殊方法都是形如__xxx__()这种形式
- 特殊方法不需要调用,它会在特定的时候自动调用
class Person:
# 定义特殊方法(魔术方法)
def __init__(self, name):
self.name = name
print('特殊方法执行了')
print('特殊方法不用调用,在实例对象创建后执行,且只执行一次')
def speak(self):
print('大家好,我是%s' % self.name)
p1 = Person('闪电侠')
p2 = Person('绿箭侠')
print(p1.name)
p2.speak()
# 输出结果:
# 特殊方法不用调用,在实例对象创建后执行,且只执行一次
# 特殊方法执行了
# 特殊方法执行了
# 闪电侠
# 大家好,我是绿箭侠
2.封装
- 出现封装的原因:使用封装可以增强数据的安全性
- 封装是面向对象的三大特性之一
- 封装是指隐藏对象中的一些不希望被外部所访问到的属性或方法
- 使用封装增加了类的复杂程度,但一定程度上也确保了数据的安全
- 隐藏属性名,使调用者无法随意修改对象的属性
- 增加了getter()和setter()⽅法,控制属性是否是只读的
- 使⽤setter()设置属性,可以进行数据的验证,确保数据的正确
- 使⽤getter()⽅法获取属性,可以在读取属性和修改属性的同时做⼀些其他的处理
- 双下划线开头的属性(__name),是对象的隐藏属性,隐藏属性只能在类的内部访问,⽆法通过对象访问
- 隐藏属性只不过是Python⾃动为属性改了⼀个名字 。其实 __name相当于_Person__name
- 这种⽅式实际上依然可以在外部访问,所以这种⽅式我们⼀般不⽤。⼀般我们会将⼀些私有属性以_开头,没有特殊情况下不要修改私有属性
class Person:
def __init__(self, name):
self.__name = name
def get_name(self):
return self.__name
def set_name(self):
self.__name = name
p = Person('闪电侠')
p.__name = '绿箭侠' # __name相当于_Person__name,所以修改不了
print(p.get_name())
# 输出结果:闪电侠
3.property装饰器
- 我们可以使⽤@property装饰器来创建只读属性,@property装饰器会将⽅法转换为相同名称的只读属性,可以与所定义的属性配合使⽤,这样可以防⽌属性被修改
class Person:
def __init__(self, name):
self._name = name
# 这是一个getter()方法
@property
def name(self):
return self._name
p = Person('闪电侠')
print(p.name) # property这个装饰器将name方法转换为对象的属性
# 输出结果:闪电侠