封装 根据 职责 将属性和方法封装到一个抽象类中
继承 实现代码的重用,相同的代码不需要重复的编写
多态 不同的对象调用相同的方法,产生不同的执行结果,增加代码的灵活度
继承的概念:子类 拥有父类的所有 方法 和 属性
子类继承父类后,可以直接 享受 父类中已经封装好的方法,不需要再次开发
子类中应该根据职责,封装子类特有的属性和方法
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:
# 接收一个动物类,动物的共有方法就是 eat
def fun(self,animal):
animal.eat()
# 定义两个继承了 动物类的 动物
dog=Dog()
cat=Cat()
# 定义统一接口访问
test=Test()
test.fun(dog)
test.fun(cat)
程序猿与投资生活实录已改名为 程序猿知秋,WX同款,欢迎关注!