封装 根据 职责 将属性和方法封装到一个抽象类中
继承 实现代码的重用,相同的代码不需要重复的编写
多态 不同的对象调用相同的方法,产生不同的执行结果,增加代码的灵活度
继承的概念:子类 拥有父类的所有 方法 和 属性
子类继承父类后,可以直接 享受 父类中已经封装好的方法,不需要再次开发
子类中应该根据职责,封装子类特有的属性和方法
C类从 B类继承, B类从 A 类继承,那么 C类就具有 B类 和 A 类的所有属性和方法
子类拥有父类 以及 父类的父类 中封装的所有 属性 和 方法
class 类(父类)pass
class Animal:def eat(self):print("动物都得吃饭....")class Dog(Animal):""" 小狗继承动物所有的属性和方法 """def run(self):print("小狗会跑步...")class XiaoBai(Dog):"""同时具备 狗和动物类的所有属性 """def color(self):print("我的颜色是白色的....")# 小狗继承动物类,具备动物类中的所有方法,同时小狗有自己独特的 跑步方法
dog=Dog()
dog.eat()
dog.run()# 小白拥有动物和狗 的所有属性和方法
xiaoBai=XiaoBai()
xiaoBai.eat()
xiaoBai.run()
xiaoBai.color()
输出结果

方法的重写
在子类中定义一个和父类同名的方法并且实现
重写之后,在运行时,只会调用子类中重写的方法,不会再调用父类封装的方法
应用场景
覆盖 父类的方法(子类中直接采用相同的方法名,完全重写)
对父类的方法进行扩展(使用 super().父类方法)
关于 super
在 Python 中 super 是一个特殊的类
super() 就是使用super 类创建出来的对象
最常 使用的场景就是在 重写父类方法时,调用 在父类中封装的方法实现
class Animal:def eat(self):print("动物都得吃饭....")def drunk(self):print("动物要喝水....")def sleep(self):print("动物要睡觉...")class Dog(Animal):# 重写 动物喝水的方法def drunk(self):print("小狗要喝牛奶....")# 扩展睡觉的方法def sleep(self):super().sleep()print("小狗还要做梦...")dog=Dog()
dog.eat()
dog.drunk()
dog.sleep()
输出结果

子类对象不能直接在自己的方法内部,访问父类的私有属性和方法
子类对象可以通过父类的公有方法 间接访问到私有属性或私有方法
私有属性、方法
是对象的隐私,不对外公开,外面不能直接访问
通常用于做一些内部的事情
class A:# 初始化属性def __init__(self):# 定义私有属性self.__name="张三"# 定义公有属性self.age=12# 定义私有方法def __hello(self):print("我是私有方法 hello.....")# 定义公有方法def world(self):print("我是公有方法,我要开始调用私有属性和方法了...")print("我的私有属性名称是:%s" %self.__name)self.__hello()class B(A):def test(self):# 通过调用父类的公有方法,打印父类的 私有属性和方法self.world()print("直接访问父类的公有属性age是:%d" %self.age)b=B()
b.test()
输出结果

子类可以拥有多个父类,并具有所有父类的方法和属性
class 类(父类1,父类2):pass
注:如果不同的父类中存在 同名的方法,子类对象在调用父类方法时,按继承 从左到右的顺序查找,找到了就执行,不再往后查找
开发时,应该尽量避免这种容易产生混淆的情况,如果父类之间 存在同名的属性或方法,应该 尽量避免使用多继承
class Person:def work(self):print("我是人,我会工作...")class Spider:def climb(self):print("我是蜘蛛,我会爬行...")class SpiderPerson(Person,Spider):def workClimb(self):print("我是蜘蛛人,我有人和蜘蛛的所有属性和方法...")spiderPerson=SpiderPerson()
spiderPerson.work()
spiderPerson.climb()
spiderPerson.workClimb()
输出结果

不同的子类对象,调用相同的 父类方法,产生不同的执行结果
多态 可以增加代码的灵活度
不会影响到类的内部设计
class Animal:def eat(self):print("我是动物要吃东西...")class Dog(Animal):def eat(self):print("我是狗,要吃骨头...")class Cat(Animal):def eat(self):print("我是猎,要吃鱼...")class Test:# 接收一个动物类,动物的共有方法就是 eatdef fun(self,animal):animal.eat()# 定义两个继承了 动物类的 动物
dog=Dog()
cat=Cat()# 定义统一接口访问
test=Test()
test.fun(dog)
test.fun(cat)

程序猿与投资生活实录已改名为 程序猿知秋,WX同款,欢迎关注!