1.面向对象的特殊方法
- 在类中可以定义一些特殊方法也称为魔术方法
- 特殊方法都是形如__xxx__()这种形式
- 特殊方法不需要我们调用,类的实例化操作会自动调用 特殊方法__init__() 方法。
class Car():
def Spkea(self):
print("我叫%s"%self.name)
a1 = Car()
a1.name = '本田'
a1.Spkea()
class Car():
def __init__(self,name):
self.name = name
def speak():
print('我叫%s'%self.name)
a1 = Car('本田')
a1.Speak()
'''
类的基本结构
class 类名():
# 对象的初始化方法
def __init__(self,.....):
......
# 其他的方法
def method1(self,.....):
...
def method2(self,.....):
...
在类中可以定义一些特殊方法
特殊方法形如__开头__结尾的方法
特殊方法不需要我们自己调用
init方法会在对象从创建以后理解执行
'''
2.封装
- 出现封装的原因:我们需要一种方式来增强数据的安全性
- 封装是面向对象的三大特性之一,封装是指隐藏对象中一些不希望被外部所访问到的属性或方法
- 我们也可以提供给一个getter()和setter()方法是外部可以访问到属性
- getter() 获取对象中指定的属性
- setter() 用来设置对象指定的属性
- 使用封装,确实增加了类的定义的复杂程度,但是它也确保了数据的安全
- 隐藏属性名,使调用这无法随意的修改对象中的属性
- 增加了getter()和setter()方法,很好控制属性是否是只读的
- 使用setter()设置属性,可以在呢及数据的验证
- 使用getter()方法获取属性,使用setter()方法设置属性可以在读取属性和修改属性的同时做一些其他的处理
- 可以为对象的属性使用双下划线开头 __xxx。双下划线开头的属性,是对象的隐藏属性,隐藏属性只能在类的内部访问,无法通过对象访问
- 其实隐藏属性只不过是Python自动为属性改了一个名字 --> _类名__属性名 例如 __name -> _Person__name
- 这种方式实际上依然可以在外部访问,所以这种方式我们一般不用。一般我们会将一些私有属性以__开头
- 一般情况下,使用__开头的属性都是私有属性,没有特殊情况下不要修改私有属性
class Person():
def __init__(self,name,age):
self.name = name
self.age = age
def speak(self):
print('我叫%s,我%d岁了'%(self.name,self.age))
a1 = Person('amy',18)
a1.speak()
a1.name = 'tom'
a1.speak()
class Person():
def __init__(self,name,age):
self.private_name = name
self.private_age = age
def speak(self):
print('我叫%s,我%d岁了'%(self.private_name,self.private_age))
a1 = Person('amy',18)
a1.speak()
a1.name = 'tom'
a1.speak()
class Person():
def __init__(self,name,age):
self.private_name = name
self.private_age = age
def speak(self):
print('我叫%s,我%d岁了'%(self.private_name,self.private_age))
def get_name(self):
return self.private_name
def set_name(self,name):
self.private_name = name
def get_age(self):
return self.private_age
def set_age(self,age):
print('修改属性')
if age > 0:
self.private_age = age
r = Person('amy',18)
r.spreak()
print(r.get_name())
r.set_name('tom')
r.speak()
print(r.get_age())
r.set_age(20)
r.speak()
'''
使用封装,确实增加了类定义的复杂程度,但是它也确保了数据的安全
1.隐藏了属性名,使使用者无法随意修改对象中的属性
2.增加了getter和setter方法,很好控制属性是否只读
如果希望属性只读的,则可以直接去调用getter方法
如果使用setter方法,可以增加数据的验证。确保数据的值是正确的
3.使用setter方法的时候我们在修改数据的同时也可以做一些其他的操作
'''
class Person():
def __init__(self,name,age):
self.private_name = name
self.private_age = age
def speak(self):
print('我叫%s,我%d岁了'%(self.private_name,self.private_age))
p = Person('amy',18)
p.speak()
print(p.private_name)
class Person():
def __init__(self,name,age):
self.__name = name
self.__age = age
def speak(self):
print('我叫%s,我%d岁了'%(self.__name,self.__age))
def get_name(self):
return self.__name
def set_name(self,name):
self.__name = name
p = Person('amy',18)
print(self.__name)
print(p.get_name())
print(p._Person__name)
print(p.set_name('tom'))
p._Person__name = 'sady'
p.speak()
3.property装饰器
- 我们可以使用@property装饰器来创建只读属性,@property装饰器会将方法转换为相同名称的只读属性,可以与所定义的属性配合使用,这样可以防止属性被修改
class Person():
def __init__(self,name):
self._name = name
def name(self):
return self._name
p = Person('amy')
print(p.name())
class Person():
def __init__(self,name):
self._name = name
@property
def name(self):
return self._nam
p = Person('amy')
print(p.name)
4.总结