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的区别。类其实还是又很多复杂的地方,在使用过程会慢慢学习到,这里只是一个入门级的说明。



猜你喜欢

转载自blog.csdn.net/qq_36523839/article/details/80227830