1、特殊方法(魔术方法)
- 在类中可以定义⼀些特殊⽅法也称为魔术⽅法
- 特殊⽅法都是形如 xxx()这种形式
- 特殊⽅法不需要我们调⽤,特殊⽅法会在特定时候⾃动调⽤
class person():
def __init__(self):
print('晚上好!')
p1 = person()
'''
类的基本结构
class 类名([父类]):
# 对象的初始化方法
def __init__(self,.....):
......
# 其他的方法
def method1(self,.....):
...
def method2(self,.....):
...
'''
2、封装
- 出现封装的原因:目前我们可以根据 对象.属性 的方式来修改属性的值,这种方式导入我们的属性非常不安全,我们需要⼀种⽅式来增强数据的安全性
- 1.属性不能随意修改 (我让你改你才可以改,我不让你改你就别改)
- 2.属性不能改为任意的值
class Car():
def __init__(self,name,color):
self.name = name
self.color = color
def run(self):
print('%s的小车起步很快'%self.name)
def laba(self):
print('%s的喇叭滴滴答'%self.color)
c = Car('雅阁','星月白')
print(c.name,c.color)
c.run()
c.laba()
雅阁 星月白
雅阁的小车起步很快
星月白的喇叭滴滴答
- 封装是⾯向对象的三⼤特性之⼀
- 封装是指隐藏对象中⼀些不希望被外部所访问到的属性或⽅法
- 如何隐藏一个对象中属性?将对象的属性名修改成一个外部不知道的名字
- 如何获取(修改)对象中的属性?需要提供⼀个getter和setter⽅法使外部可以访问到属性
- getter() 获取对象中指定的属性
- setter() ⽤来设置对象指定的属性
- 使⽤封装,确实增加了类的定义的复杂程度,但是它也确保了数据的安全
- 1.隐藏属性名,使调⽤这⽆法随意的修改对象中的属性
- 2.增加了getter和setter⽅法,很好控制属性是否是只读
- 3.如果希望属性只读的,则可以直接去调用getter方法
- 4.如果使用setter方法,可以增加数据的验证,确保数据的值是正确的
- 5.使⽤getter()⽅法获取属性,使⽤setter()⽅法设置属性可以在读取属 性和修改属性的同时做⼀些其他的处理
class Dog:
def __init__(self,name):
self.hidden_name = name
def speak(self):
print('大家好,我是%s'%self.hidden_name)
def get_name(self):
return self.hidden_name
def set_name(self,name):
self.hidden_name = name
d.set_name('萨摩')
print(d.get_name())
d.speak()
萨摩
大家好,我是萨摩
- 可以为对象的属性使⽤双下划线开头 __xxx。双下划线开头的属性,是对象 的隐藏属性,隐藏属性只能在类的内部访问,⽆法通过对象访问
- 其实隐藏属性只不过是Python⾃动为属性改了⼀个名字 --> _类名__属性 名 例如 __name -> _Person__name
- 这种⽅式实际上依然可以在外部访问,所以这种⽅式我们⼀般不⽤。⼀般我 们会将⼀些私有属性以_开头
- ⼀般情况下,使⽤_开头的属性都是私有属性,没有特殊情况下不要修改私有 属性
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('葫芦妹')
print(p._name)
3、property装饰器
- 我们可以使⽤@property装饰器来创建只读属性,@property装饰器会将⽅法转换为相同名称的只读属性,可以与所定义的属性配合使⽤,这样可以防⽌属性被修改
class Person():
def __init__(self,name):
self._name = name
@property
def name(self):
print('get方法执行了')
return self._name
@name.setter
def name(self,name):
print('set方法执行了')
self._name = name
p = Person('葫芦娃')
p.name = '超人'
print(p.name)