我们在学习python类的时候,总会碰见书上的类中有__init__()这样一个函数,很多同学百思不得其解,其实它就是python的构造方法。
构造方法类似于类似init()这种初始化方法,来初始化新创建对象的状态,在一个对象被创建以后会立即调用,比如像实例化一个类:
f = FooBar() f.init()
使用构造方法就能让它简化成如下形式:
f = FooBar()
你可能还没理解到底什么是构造方法,什么是初始化,下面我们再来举个例子:
class FooBar: def __init__(self): self.somevar = 42 >>>f = FooBar() >>>f.somevar42
我们会发现在初始化FooBar中的somevar的值为42之后,实例化直接就能够调用somevar的值;如果说你没有用构造方法初始化值得话,就不能够调用。
在明白了构造方法之后,我们来点进阶的问题,那就是构造方法中的初始值无法继承的问题。
例子:
class Bird: def __init__(self): self.hungry = True def eat(self): if self.hungry: print('Ahahahah') else: print('No thanks!') class SongBird(Bird): def __init__(self): self.sound = 'Squawk' def sing(self): print(self.sound) if __name__ == "__main__": sb = SongBird() sb.sing() #能正常输出 sb.eat() #报错,因为songgird中没有hungry特性
那解决这个问题的办法有两种:
1、调用未绑定的超类构造方法(多用于旧版python阵营)
class SongBird(Bird): def __init__(self): Bird.__init__(self) self.sound = 'Squawk' def sing(self): print(self.sound)
原理:在调用了一个实例的方法时,该方法的self参数会自动绑定到实例上(称为绑定方法);如果直接调用类的方法(比如Bird.__init__),那么就没有实例会被绑定,可以自由提供需要的self参数(未绑定方法)。
2、使用super函数(只在新式类中有用,建议用此)
class SongBird(Bird): def __init__(self): super(SongBird,self).__init__() self.sound = 'Squawk' def sing(self): print(self.sound)
原理:它会查找所有的超类,以及超类的超类,直到找到所需的特性为止。
解决上面例子报错问题的正确代码为(使用super函数):
class Bird:
def __init__(self):
self.hungry = True
def eat(self):
if self.hungry:
print('Ahahahah')
else:
print('No thanks!')
class SongBird(Bird):
def __init__(self):
self.sound = 'Squawk'
super(SongBird,self).__init__() #使用super函数(只在新式类中有用);
#原理:它会查找所有的超类,以及超类的超类,直到找到所需的特性为止。
def sing(self):
print(self.sound)
if __name__ == "__main__":
sb = SongBird()
sb.sing() #能正常输出
sb.eat() #报错,因为songgird中没有hungry特性
OK,搞定!!!
【参考】
https://www.cnblogs.com/liyichen/p/5931840.html
点滴分享,福泽你我!Add oil!
转载本文请联系原作者获取授权,同时请注明本文来自张伟科学网博客。
链接地址:https://wap.sciencenet.cn/blog-3428464-1243122.html?mobile=1
收藏