时间:2021-07-01 10:21:17 帮助过:35人阅读
这里不区分经典类和新式类,下面分析的对新式类和经典类都适用
对于类中的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):
- passif 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"
- passif name=="main":
- dg=jinmao()
- print dg.dict
此时的结果一样是
- {}
在类的多继承中会产生什么状况呢?(在多继承中会运行类的继承参数中的第一个参数声明的父类中的init函数,如果父类中没有init函数,继续寻找父类的父类中有没有,以此类推。。。如果找到了头还是没有,则换为第二个参数声明的父类,过程如第一个参数,知道找到init函数为止,如果都没有找到,则不初始化),代码可以根据前面例子自己测试。
以上就是python类继承讲解的详细内容,更多请关注Gxl网其它相关文章!