Python基础——类3(继承、重写、super、多重继承)

一、继承简介

引入

有一个类,能够实现我们需要的大部分功能,但是不能实现全部功能,如何能让这个类来实现全部的功能呢?

  • ① 直接修改这个类,在这个类中添加我们需要的功能
    • 修改起来会比较麻烦,并且会违反OCP原则
  • ② 直接创建一个新的类
    • 创建一个新的类比较麻烦,并且需要大量的进行复制粘贴,会出现大量的重复性代码
  • ③ 直接从父类中来继承它的属性和方法
    • 继承是面向对象三大特性之一
    • 通过继承我们可以使一个类获取到其他类中的属性和方法
    • 在定义类时,可以在类名后的括号中指定当前类的父类(超类、基类、super)
    • 子类(衍生类)可以直接继承父类中的所有的属性和方法

通过继承可以直接让子类获取到父类的方法或属性,避免编写重复性的代码,并且也符合OCP原则,所以我们经常需要通过继承来对一个类进行扩展

代码实例

# 定义 Dragon_Ball 类
class Dragon_Ball:
    
    def Skill(self):
        print("龟派气功")
 
# 创建一个类实例
d = Dragon_Ball()

# 调用Skill方法
d.Skill()

# 定义 Wukong 类,继承 Dragon_Ball 类
class Wukong(Dragon_Ball):

    def Skill_1(self):
        print('元气弹') 
  
# 创建一个类实例
p = Wukong()

# 调用Skill方法
p.Skill()

# 调用Skill_1方法
p.Skill_1()

在这里插入图片描述

  • 在创建类时,如果省略了父类,则默认父类为object
  • object是所有类的父类,所有类都继承自object
# 在创建类时,如果省略了父类,则默认父类为object
# object是所有类的父类,所有类都继承自object
class Dragon_Ball(object):
    pass
  • issubclass() 检查一个类是否是另一个类的子类
# issubclass() 检查一个类是否是另一个类的子类
print(issubclass(Wukong, Dragon_Ball))
print(issubclass(Dragon_Ball, object))
  • isinstance()用来检查一个对象是否是一个类的实例
# isinstance()用来检查一个对象是否是一个类的实例
# 如果这个类是这个对象的父类,也会返回True
# 所有的对象都是object的实例
print(isinstance(p, Dragon_Ball))
print(isinstance(Wukong, object))
print(isinstance(Dragon_Ball, object))

在这里插入图片描述

二、重写

  • 在子类中如果有和父类同名的方法,则通过子类实例去调用方法时,会调用子类的方法而不是父类的方法,这个特点我们成为叫做方法的重写(覆盖,override)
# 定义一个类 Dragon_Ball
class Dragon_Ball:
    
    def Skill(self):
        print("龟派气功")

# 定义 Wukong 类,继承 Dragon_Ball 类
class Wukong(Dragon_Ball):
    
    def Skill(self):
        print("元气弹")    
# 创建Wukong类的实例
d = Wukong()
d.Skill()

在这里插入图片描述

  • 当我们调用一个对象的方法时,会优先去当前对象中寻找是否具有该方法,如果有则直接调用,如果没有,则去当前对象的父类中寻找,如果父类中有则直接调用父类中的方法,如果没有,则去父类的父类中寻找,以此类推,直到找到object,如果依然没有找到,则报错
class A(object):
    def test(self):
        print('AAA')

class B(A):
    def test(self):
        print('BBB')

class C(B):
    def test(self):
        print('CCC')   

# 创建一个c的实例
c = C()
c.test()

在这里插入图片描述

三、super()

  • 希望可以直接调用父类的__init__来初始化父类中定义的属性
  • super() 可以用来获取当前类的父类, 并且通过super()返回对象调用父类方法时,不需要传递self
class Dragon_Ball:
    def __init__(self, name):
        self._name = name
    
    def Skill(self):
        print("龟派气功")
        
    @property
    def name(self):
        return self._name
    
    @name.setter
    def name(self, name):
        self._name = name
      
# 父类中的所有方法都会被子类继承,包括特殊方法,也可以重写特殊方法
class Wukong(Dragon_Ball):
    
    def __init__(self, name, age):
        # 希望可以直接调用父类的__init__来初始化父类中定义的属性
        # super() 可以用来获取当前类的父类,
        # 并且通过super()返回对象调用父类方法时,不需要传递self
        super().__init__(name)
        self._age = age
    
    def Skill_1(self):
        print("元气弹")
    
    @property
    def age(self):
        return self._age
    
    @age.setter
    def age(self, age):
        self._age = age

d = Wukong('孙悟饭',18) 

print(d.name)       
print(d.age)       

在这里插入图片描述

四、多重继承

  • 在Python中是支持多重继承的,也就是我们可以为一个类同时指定多个父类
  • 可以在类名的()后边添加多个类,来实现多重继承
  • 多重继承,会使子类同时拥有多个父类,并且会获取到所有父类中的方法
class A(object):
    def test(self):
        print('AAA')

class B(object):
    def test2(self):
        print('BBB')

# 类名.__bases__ 这个属性可以用来获取当前类的所有父类    

# 类C只继承类A 
class C(A):
    pass
# 类C只继承类A的父类
print(C.__bases__) # (<class '__main__.A'>,)

# 类C同时继承类A和类B
class C(A,B):
    pass
# 类C同时继承类A和类B的父类
print(C.__bases__) # (<class '__main__.A'>, <class '__main__.B'>)
  • 在开发中没有特殊的情况,应该尽量避免使用多重继承,因为多重继承会让我们的代码过于复杂
  • 如果多个父类中有同名的方法,则会先在第一个父类中寻找,然后找第二个,然后找第三个…,前边父类的方法会覆盖后边父类的方法
# 如果多个父类中有同名的方法,则会先在第一个父类中寻找,然后找第二个,然后找第三个.....
# 前边父类的方法会覆盖后边父类的方法
class A(object):
    def test(self):
        print('A中的test()方法~~')

class B(object):
    def test(self):
        print('B中的test()方法~~')

# 类A在先,类B在后
class C(A,B):
    pass

d = C()
d.test()

# 类B在先,类A在后
class C(B,A):
    pass

d = C()
d.test(

在这里插入图片描述

  • 24
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值