Python——方法重写与构造方法

来源:互联网 发布:方便面 减肥 知乎 编辑:程序博客网 时间:2024/04/29 23:28

一、Python构造方法
先看一个例子,如下:

# _*_ coding:utf-8 _*___metaclass__=typeclass A:    def init(self,num):        self.num=num运算结果:==========RESTART: C:\Users\Mr_Deng\Desktop\test.py==========>>> test=A()>>> test.init(10)>>> test.num10>>> 

这种方法是在类中自行定义了一个初始化函数并对num赋值,但是对该值赋值需要在对象实例化之后,通过实例化的对象调用初始化方法。因此,就初始化操作而言显得不够灵活,可以通过构造方法解决这个问题。与普通方法不同,当一个对象创建时,在类的构造方法就会被调用,对实例化对象进行初始化。构造方法的定义和使用如下:

# _*_ coding:utf-8 _*___metaclass__=typeclass 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__=typeclass 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__=typeclass 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__=typeclass 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__=typeclass 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__=typeclass 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中使用B.init(self)方法,将当前实例作为self参数提供给未绑定方法,使得子类也拥有了与父类初始化中相同的属性和方法。当然,也可以不使用未绑定方法而使用新版中的super方法,如下:

# _*_ coding:utf-8 _*___metaclass__=typeclass 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>>> 
0 0