封装
将属性和方法书写到类的里面的操作即为封装
封装可以为属性和方法添加私有权限
继承
Python面向对象的继承指的是多个类之间的所属关系,即子类默认继承父类的所有属性和方法
在Python中,所有类默认继承object类, object类是顶级类或基类;其他子类叫做派生类
单继承
# 师傅类
class Master(object):
def __init__(self):
self.kongfu = '[古法煎饼果子配方]'
def make_cake(self):
print(f'运用{self.kongfu}制作煎饼果子')
# 徒弟类
class Prenice(Master):
pass
# 创建对象
dachui = Prenice()
# 对象访问实例属性
print(dachui.kongfu)
# 对象调用实例方法
dachui.make_cake()
多继承
多继承意思就是一个类同时继承了多个父类
注意:当一个类有多个父类的时候,默认使用第一个父类的同名属性和方法
# 师傅类
class Master(object):
def __init__(self):
self.kongfu = '[古法煎饼果子配方]'
def make_cake(self):
print(f'运用{self.kongfu}制作煎饼果子')
# 学校类
class School(object):
def __init__(self):
self.kongfu = '[新煎饼果子配方]'
def make_cake(self):
print(f'运用{self.kongfu}制作煎饼果子')
# 徒弟类
class Prenice(School, Master):
pass
# 创建对象
dachui = Prenice()
# 对象访问实例属性
print(dachui.kongfu)
# 对象调用实例方法
dachui.make_cake()
重写父类属性方法,调用父类属性方法,多层继承
# 师傅类
class Master(object):
def __init__(self):
self.kongfu = '[古法煎饼果子配方]'
def make_cake(self):
print(f'运用{self.kongfu}制作煎饼果子')
# 学校类
class School(object):
def __init__(self):
self.kongfu = '[新煎饼果子配方]'
def make_cake(self):
print(f'运用{self.kongfu}制作煎饼果子')
# 徒弟类
class Prenice(School, Master):
def __init__(self):
super().__init__()
# 重写父类属性
self.kongfu = '[独创配方]'
# 重写父类方法
def make_cake(self):
# 如果先调用了父类的属性和方法,会覆盖子类属性,故在调用前,先调用自己子类的初始化
self.__init__()
print(f'运用{self.kongfu}制作煎饼果子')
# 调用父类方法,为保证调用的父类属性,必须在调用方法前调用父类的初始化
def make_master_cake(self):
Master.__init__(self)
Master.make_cake(self)
def make_school_cake(self):
School.__init__(self)
School.make_cake(self)
# 徒孙类
# 多层继承
class Tusun(Prenice):
pass
# 创建对象
dachui = Prenice()
dachui.make_cake()
dachui.make_master_cake()
dachui.make_school_cake()
dachui.make_cake()
# 徒孙
xiaochui = Tusun()
xiaochui.make_cake()
xiaochui.make_school_cake()
xiaochui.make_master_cake()
python中可以为实例属性和方法设置私有权限,即设置某个实例属性或方法不继承给子类。
设置私有权限的方法:在属性名和方法名前面加上两个下划线 __
一般定义函数名get_xx用来获取私有属性,定义set_xx修改私有属性值
多态
多态指的是一类事物具有多种形态。多态的概念依赖于继承。
多态是一种使用对象的方式,子类重写父类方法,调用不同子类对象的相同父类方法,可以产生不同的执行结果。
实现步骤:
定义父类,提供公共方法
定义子类,并重写父类方法
传递子类对象给调用者,可以看到不同的子类执行效果不同。
# 多态
class Dog(object):
def work(self): # 父类提供统一的方法
print('指哪打哪...')
class ArmDog(Dog):
def work(self): # 子类重写父类同名方法
print('追击敌人...')
class DrugDog(Dog):
def work(self):
print('追查毒品...')
class Person(object):
def work_with_dog(self, dog): # 传入不同的对象,执行不同的代码,即不同的work函数
dog.work()
ad = ArmDog()
dd = DrugDog()
dachui = Person()
dachui.work_with_dog(ad)
dachui.work_with_dog(dd)
类属性与实例属性
类属性是类对象所拥有的属性,被该类的所有实例对象所拥有,可以使用类对象或实例对象访问
类属性只能通过类对象修改,不能通过实例对象修改,如果通过实例对象修改类属性,表示的是创建了一个实例属性。
class Dog(object):
tooth = 10
wangcai = Dog()
xiaohei = Dog()
print(Dog.tooth) # 10
print(wangcai.tooth) # 10
print(xiaohei.tooth) # 10
实例属性
class Dog(object):
def __init__(self):
self.age = 5
def info_print(self):
print(self.age)
wangcai = Dog()
print(wangcai.age) # 5
# print(Dog.age) # 报错:实例属性不能通过类访问
wangcai.info_print() # 5
类方法和静态方法
类方法:需要用装饰器@classmethod来标识其为类方法,第一个参数必须是类对象,一般以cls作为第一个参数
当方法中需要使用类对象(如访问私有属性等)时,定义类方法
类方法一般和类属性配合使用
class Dog(object):
__tooth = 10
@classmethod
def get_tooth(cls):
return cls.__tooth
wangcai = Dog()
result = wangcai.get_tooth()
print(result) # 10
静态方法
需要通过装饰器@staticmethod来进行修饰,静态方法既不需要传递类对象也不需要传递实例对象(形参没有self/cls)
静态方法可以通过实例对象和类对象访问
当方法中既不需要使用实例对象(如实例对象,实例属性), 也不需要使⽤类对象 (如类属性、类方法、创建实例等)时,定义静态方法;取消不需要的参数传递,有利于减少不必要的内存占用和性能消耗
class Dog(object):
@staticmethod
def info_print():
print('这是一个狗类,用于创建狗实例')
wangcai = Dog()
# 静态方法既可以使用对象访问也可以使用类访问
wangcai.info_print()
Dog.info_print()
dict
class A(object):
a = 0
def __init__(self):
self.b = 1
aa = A()
# 返回类内部所有属性和方法对应的字典
print(A.__dict__)
# 返回实例属性和值组成的字典
print(aa.__dict__)