Python——方法重写与构造方法
一、Python构造方法
先看一个例子,如下:
# _*_ coding:utf-8 _*_ __metaclass__=type class A: def init(self,num): self.num=num 运算结果: ==========RESTART: C:\Users\Mr_Deng\Desktop\test.py========== >>> test=A() >>> test.init(10) >>> test.num 10
这种方法是在类中自行定义了一个初始化函数并对num赋值,但是对该值赋值需要在对象实例化之后,通过实例化的对象调用初始化方法。因此,就初始化操作而 言显得不够灵活,可以通过构造方法解决这个问题。与普通方法不同,当一个对象创建时,在类的构造方法就会被调用,对实例化对象进行初始化。构造方法的定义 和使用如下:
# _*_ coding:utf-8 _*_ __metaclass__=type class A: def __init__(self): self.num=10 self.data=20 def output(self): print(self.num,' ',self.data) 运算结果: ==========RESTART: C:\Users\Mr_Deng\Desktop\test.py========== >>> test=A() >>> test.output() 10 20
二、方法的重写和重载
# _*_ coding:utf-8 _*_ __metaclass__=type class A: def output(self): print('This is a test case for class A') class B(A): pass 运算结果: ==========RESTART: C:\Users\Mr_Deng\Desktop\test.py========== >>> testA=A() >>> testA.output() This is a test case for class A >>> testB=B() >>> testB.output() This is a test case for class A
实际上在B中相当于是继承类A的output方法,所以在B中没有重写该方法的情况下,输出的结果与A一致,实现继承父类方法的重写如下:
# _*_ coding:utf-8 _*_ __metaclass__=type class A: def output(self): print('This is a test case for class A') class B(A): def output(self): print('This is a test case for class B') 运算结果: ==========RESTART: C:\Users\Mr_Deng\Desktop\test.py========== >>> testA=A() >>> testA.output() This is a test case for class A >>> testB=B() >>> testB.output() This is a test case for class B
对于子类方法的重写,就是对与父类相同的方法名进行函数体的改写,从而表现出父类与子类的不同特性。但是,对于初始化操作而言,不能直接改写,否则可能出错。
# _*_ coding:utf-8 _*_ __metaclass__=type class A: def __init__(self): self.flag=1 def write(self): if self.flag==1: self.flag=0 print('Write file success') else: print('Write file fail') 运算结果: ==========RESTART: C:\Users\Mr_Deng\Desktop\test.py========== >>> testA=A() >>> testA.write() Write file success >>> testA.write() Write file fail
这个类的作用是进行文件的写操作,但是只能写一次,当第二次进行写操作时报错。若是有另外一个类继承该类,并进行了类的初始化定义,那么结果就会出错,如下:
# _*_ coding:utf-8 _*_ __metaclass__=type class A: def __init__(self): self.flag=1 def write(self): if self.flag==1: self.flag=0 print('Write file success') else: print('Write file fail') class B(A): def __init__(self): self.s='Test case for class B' def output(self): print(self.s) 运算结果: ==========RESTART: C:\Users\Mr_Deng\Desktop\test.py========== >>> testB=B() >>> testB.output() Test case for class B >>> testB.write() Traceback (most recent call last): File "<pyshell#40>", line 1, in <module> testB.write() File "C:\Users\Mr_Deng\Desktop\test.py", line 7, in write if self.flag==1: AttributeError: 'B' object has no attribute 'flag'
在这个例子中类B继承了父类A,但是在B中却重新定义了构造方法,这样使得B的实例对象,尽管拥有了父类A的write方法,但是由于没有flag变量的初始化,在调用父类的write方法时报错。为了解决这个问题,可以使用未绑定的超类构造方法,如下:
# _*_ coding:utf-8 _*_ __metaclass__=type class A: def __init__(self): self.flag=1 def write(self): if self.flag==1: self.flag=0 print('Write file success') else: print('Write file fail') class B(A): def __init__(self): A.__init__(self) self.s='Test case for class B' def output(self): print(self.s) 运算结果: ==========RESTART: C:\Users\Mr_Deng\Desktop\test.py========== >>> testB=B() >>> testB.write() Write file success >>> testB.output() Test case for class B >>>
在子类B中使用A.__init__(self)方法,将当前实例作为self参数提供给未绑定方法,使得子类也拥有了与父类初始化中相同的属性和方法。当然,也可以不使用未绑定方法而使用新版中的super方法,如下:
# _*_ coding:utf-8 _*_ __metaclass__=type class A: def __init__(self): self.flag=1 def write(self): if self.flag==1: self.flag=0 print('Write file success') else: print('Write file fail') class B(A): def __init__(self): super(B,self).__init__() self.s='Test case for class B' def output(self): print(self.s) 运算结果: ==========RESTART: C:\Users\Mr_Deng\Desktop\test.py========== >>> testB=B() >>> testB.write() Write file success >>> testB.write() Write file fail >>> testB.output() Test case for class B >>>
From:https://blog.csdn.net/u010480899/article/details/52807039

浙公网安备 33010602011771号