python 类的继承
对于许多文章讲解python类的继承,大多数都是说一些什么oop,多态等概念,我认为这样可能对有一定基础的开发者帮助不是那么大,不如直接用在各种情况下所写的代码,来展示对于某一种代码情况,代码运行会有什么效果。这样可能对开发者的帮助更大。不说废话,直接上代码。
这里不区分经典类和新式类,下面分析的对新式类和经典类都适用
对于类中的init函数,只是一个初始化是调用的一个函数(ps:初始化和创建实例并不是一个过程,实例的创建是通过一个create函数来完成的),如果在子类中没有显示的声明init函数,则子类就会调用父类的init函数,但是不会再调用父类的父类中的init函数,如果显示的声明了init 函数,则在子类的初始化的时候就不会调用父类的初始化函数,只会调用子类中声明的init函数, 同时在子类实例中也不会有父类init函数中声明的属性,
例子:
class animal():
name="hh"
sex="man"
def __init__(self):
self.height=10
self.weight=50
def deception(self):
print "ansible.height:"+self.height+" animal.weight:"+self.weight
def run(self):
print "animal is running...."
class dog(animal):
def __init__(self):
pass
if __name__=="__main__":
dg=dog()
print dg.__dict__
此时运行的结果为
{}
当把dog类修改为如下时(ps:此时没有显示的声明init方法):
class dog(animal):
def run(self):
print "dog is running..."
此时由于直接调用的父类animal的init方法,结果如下:
{'weight': 50, 'height': 10}
如果此时有一个类继承dog类,此时会出现什么情况呢?(python解释器先在子类中寻找init方法,如果没有找到,再从父类中找,直到找到为止,并运行,并且不再运行父类的父类的init方法,此时没有运行的init方法中的创建的属性是没有的,例如上面的例子,第一次运行时得到的例子中并没有weight和height属性)
class animal():
name="hh"
sex=""
def __init__(self):
self.height=10
self.weight=50
def deception(self):
print "ansible.height:"+self.height+" animal.weight:"+self.weight
def run(self):
print "animal is running...."
class dog(animal):
def __init__(self):
pass
def run(self):
print "dog is running..."
class jinmao(dog):
# def __init__(self):
# self.ji="jinmao"
pass
if __name__=="__main__":
dg=jinmao()
print dg.__dict__
此时的结果一样是
{}
在类的多继承中会产生什么状况呢?(在多继承中会运行类的继承参数中的第一个参数声明的父类中的init函数,如果父类中没有init函数,继续寻找父类的父类中有没有,以此类推。。。如果找到了头还是没有,则换为第二个参数声明的父类,过程如第一个参数,知道找到init函数为止,如果都没有找到,则不初始化),代码可以根据前面例子自己测试。
对于在子类中调用父类中的方法的super的使用与特性。
总结:如果想了解python虚拟机具体是怎么创建类的(具体到当加载一个.pyc文件时,是怎么通过c语言的代码逻辑来把类对象放到一块内存中的,我也在了解这方面的内容,希望咱们一块探索)
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8