时间:2022-12-22 09:54:49 | 栏目:Python代码 | 点击:次
之前一直对于python类的继承机制认知的比较混乱,今天学习记录一下。
class parent(): def __init__(self): self.a="这是父类a" print("父类初始化") def fuc(self): print(self.a) class child(parent): def __init__(self): print("子类初始化") c=child() c.fuc()
运行结果为:
子类初始化
AttributeError: 'child' object has no attribute 'a'
Process finished with exit code 1
可见子类没有继承父类中属性
class parent(): def __init__(self): self.a="这是父类a" print("父类初始化") def fuc(self): print(self.a) class child(parent): def __init__(self): self.a="这是子类a" print("子类初始化") c=child() c.fuc()
运行结果:
子类初始化
这是子类a
可见在子类中继承了父类的方法
class parent(): def __init__(self): self.a="这是父类a" print("父类初始化") def fuc(self): print(self.a) class child(parent): def __init__(self): super(child, self).__init__() print("子类初始化") c=child() c.fuc()
运行结果:
父类初始化
子类初始化
这是父类a
使用super方法程序在实例化子类的时候会首先调用父类中__init__,并将属性赋予子类
class parent(): def __init__(self): self.a="这是父类a" print("父类初始化") def fuc(self): print(self.a) class child(parent): def __init__(self,m): super(child, self).__init__() print("子类初始化") self.m=m c=child(1) print(c.m)
运行结果:
父类初始化
子类初始化
1
class parent(): def __init__(self,m): self.a="这是父类a" print("父类初始化") self.m = m def fuc(self): print(self.m) class child(parent): def __init__(self,m): super(child, self).__init__(m) print("子类初始化") c=child(1) c.fuc()
运行结果:
父类初始化
子类初始化
1
当子类中与父类中有同样的属性时子类中的属性会覆盖父类的属性