liujjun 发表于 2018-8-12 11:09:02

Python面向对象2.7类继承

继承类定义
  单继承

[*]  class <类名>(父类名)
[*]  <代码快>
  类的多重继承

[*]  class 类名(父类1,父类2,....,父类n)
[*]     <代码块>
  

[*]  Python的类可以继承多个类,Java和C#中则只能继承一个类
[*]  Python的类如果继承了多个类,那么其寻找方法的方式有两种,分别是:深度优先和广度优先
https://blog.ansheng.me/static/uploads/2016/12/1483021455.png

[*]  当类是经典类时,多继承情况下,会按照深度优先方式查找
[*]  当类是新式类时,多继承情况下,会按照广度优先方式查找
  经典类和新式类,从字面上可以看出一个老一个新,新的必然包含了跟多的功能,也是之后推荐的写法,从写法上区分的话,如果 当前类或者父类继承了object类,那么该类便是新式类,否则便是经典类。
https://blog.ansheng.me/static/uploads/2016/12/1483021475.png
https://blog.ansheng.me/static/uploads/2016/12/1483021498.png
  经典类多继承

[*]  class D:
[*]  
[*]      def bar(self):
[*]        print 'D.bar'
[*]  
[*]  class C(D):
[*]  
[*]      def bar(self):
[*]        print 'C.bar'
[*]  
[*]  class B(D):
[*]  
[*]      def bar(self):
[*]        print 'B.bar'
[*]  
[*]  class A(B, C):
[*]  
[*]      def bar(self):
[*]        print 'A.bar'
[*]  
[*]  a = A()
[*]  # 执行bar方法时
[*]  # 首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去D类中找,如果D类中么有,则继续去C类中找,如果还是未找到,则报错
[*]  # 所以,查找顺序:A --> B --> D --> C
[*]  # 在上述查找bar方法的过程中,一旦找到,则寻找过程立即中断,便不会再继续找了
[*]  a.bar()
  新式类多继承

[*]  class D(object):
[*]  
[*]      def bar(self):
[*]        print 'D.bar'
[*]  
[*]  class C(D):
[*]  
[*]      def bar(self):
[*]        print 'C.bar'
[*]  
[*]  class B(D):
[*]  
[*]      def bar(self):
[*]        print 'B.bar'
[*]  
[*]  class A(B, C):
[*]  
[*]      def bar(self):
[*]        print 'A.bar'
[*]  
[*]  a = A()
[*]  # 执行bar方法时
[*]  # 首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去C类中找,如果C类中么有,则继续去D类中找,如果还是未找到,则报错
[*]  # 所以,查找顺序:A --> B --> C --> D
[*]  # 在上述查找bar方法的过程中,一旦找到,则寻找过程立即中断,便不会再继续找了
[*]  a.bar()
  

[*]  经典类:首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去D类中找,如果D类中么有,则继续去C类中找,如果还是未找到,则报错
[*]  新式类:首先去A类中查找,如果A类中没有,则继续去B类中找,如果B类中么有,则继续去C类中找,如果C类中么有,则继续去D类中找,如果还是未找到,则报错
  **注意:88在上述查找过程中,一旦找到,则寻找过程立即中断,便不会再继续找
页: [1]
查看完整版本: Python面向对象2.7类继承