时间: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
当子类中与父类中有同样的属性时子类中的属性会覆盖父类的属性