• python的多继承关系


    python和C++一样,支持多继承。概念虽然容易,但是困难的工作是如果子类调用一个自身没有定义的属性,它是按照何种顺序去到父类寻找呢,尤其是众多父类中有多个都包含该同名属性。

    class P1 #(object): 
       def foo(self):           
           print 'p1-foo' 
     
    class P2 #(object): 
       def foo(self): 
           print 'p2-foo' 
       def bar(self): 
           print 'p2-bar' 
     
    class C1 (P1,P2): 
       pass  
     
    class C2 (P1,P2): 
       def bar(self): 
           print 'C2-bar'   
     
    class D(C1,C2): 
       pass 

    对经典类和新式类来说,属性的查找顺序是不同的。现在我们分别看一下经典类和新式类两种不同的表现

    1、经典类

    1. d=D() 
    2. d.foo() # 输出 p1-foo 
    3. d.bar() # 输出 p2-bar 

    实例d调用foo()时,搜索顺序是 D => C1 => P1

    实例d调用bar()时,搜索顺序是 D => C1 => P1 => P2

    换句话说,经典类的搜索方式是按照“从左至右,深度优先”的方式去查找属性。d先查找自身是否有foo方法,没有则查找最近的父类C1里是否有该方法,如果没有则继续向上查找,直到在P1中找到该方法,查找结束。

    2、新式类

    使用新式类要去掉第一段代码中的注释

    class P1 :# (object):新式类默认继承object
        def foo(self):
            print('p1-foo')
    
    
    class P2 : # (object):
        def foo(self):
            print('p2-foo')
    
        def bar(self):
            print('p2-bar')
    
    
    class C1(P1, P2):
        pass
    
    
    class C2(P1, P2):
        def bar(self):
            print( 'C2-bar')
    
    
    class D(C1, C2):
        pass
    
    d=D()
    d.foo() # 输出 p1-foo
    d.bar() # 输出 p2-bar
    print(D.__mro__)
    1. d=D() 
    2. d.foo() # 输出 p1-foo 
    3. d.bar() # 输出 c2-bar 

    实例d调用foo()时,搜索顺序是 D => C1 => C2 => P1

    实例d调用bar()时,搜索顺序是 D => C1 => C2

    可以看出,新式类的搜索方式是采用“广度优先”的方式去查找属性。

  • 相关阅读:
    PLC 输入输出接线示意图
    光耦的使用
    windows server 2008R2 搭建FTP服务器的步骤:
    C# semaphore的使用
    Multisim模拟 达灵顿管,防反接电路,恒流源电路
    一些芯片资料
    220V交流转5V直流电路详细
    STM32中的模拟IIC使用
    基于C8T6的DA14580蓝牙方案
    基本元件实验:继电器
  • 原文地址:https://www.cnblogs.com/sui776265233/p/10003241.html
Copyright © 2020-2023  润新知