python3中类的继承以及self和super的区别

python中类的继承:

    子类继承父类,及子类拥有了父类的 属性方法

python中类的初始化都是__init__()。所以父类和子类的初始化方式都是__init__(),但是如果子类初始化时没有这个函数,那么它便调用父类的__init__();如果实现了这个函数,就会覆盖父类的初始化函数。如果继承父类的__init__(),就需要在子类中显示调用这个函数。实现如下:

class Animal(object):
    def __init__(self):
        self.name = "我是父类"

class Panda(Animal):
    def __init__(self):
        super().__init__()    #使用super的方式来显示调用父类的__init__()函数

if __name__=="__main__":
    panda = Panda()    #实例化Panda
    print(panda.name)
我是父类        #输出可以看出使用了父类的初始化函数并有了name属性

子类也可以在初始化函数中定义自己的属性:

class Animal(object):
    def __init__(self):
        self.name = "我是父类"

class Panda(Animal):
    def __init__(self):
        super().__init__()
        self.myname = "panda"

if __name__=="__main__":
    panda = Panda()
    print(panda.myname)
panda        #子类自己的属性


self和super的区别:

    ★self是首先调用自身的方法如果自身没有再去父类中找;super是直接从父类中找方法

    ★self是类,super是预编译指令

    ★self class 和super calss的输出是一样的

class Animal(object):
    def __init__(self):
        self.name = "我是父类"

    def A(self):                    #父类中的A方法
        print("父类的A方法")

class Panda(Animal):
    def __init__(self):
        super().__init__()
        self.myname = "panda"

    def A(self):                    #子类中的A方法
        print("子类的A方法")

    def B(self):
        self.A()        #self调用A
        super().A()     #super调用A


if __name__=="__main__":
    panda = Panda()
    panda.B()            #通过B函数来调用A方法,查看self和super的区别
子类的A方法            #我们说过self是先从自身找方法,没有再去父类找
父类的A方法            #而super则是直接从父类中找

如果子类中没有A方法那么会输出:

父类的A方法        #子类没有,self从父类中找
父类的A方法

父类没有则会报错


以上则是python中继承的基础讲解,以及self和super的区别。类其实还是又很多复杂的地方,在使用过程会慢慢学习到,这里只是一个入门级的说明。



  • 6
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值