zoukankan      html  css  js  c++  java
  • python 3 mro

    __mro__

    1.只有在python2中才分新式类和经典类,python3中统一都是新式类
    2.在python2中,没有显式的继承object类的类,以及该类的子类,都是经典类
    3.在python2中,显式地声明继承object的类,以及该类的子类,都是新式类
    3.在python3中,无论是否继承object,都默认继承object,即python3中所有类均为新式类
    

    __mro__三次进化

    经典类(classic class)的深度遍历。

    Python 2.2 的新式类(new-style class)预计算。

    Python 2.3 的新式类的C3 算法。它也是 Python 3 唯一支持的方式。

    简单说下实现:

    前面两种都是基于深度遍历的,但是第一种重复保留的是第一个,第二种,重复保留的是最后一个

    第三种就是基于c3算法的

    为啥要用c3算法?是为了解决原来基于深度优先搜索算法不满足本地优先级,和单调性的问题。

    菱形


    zx
    (<class 'main.zx'>, <class 'main.c'>, <class 'main.b'>, <class 'main.e'>, <class 'main.d'>, <class 'main.g'>, <class 'main.f'>, <class 'main.a'>, <class 'object'>)

    class a:
        def f1(self):
            print("a")
    
    class b(a):
        def f1(self):
            print("b")
    
    class c(b):
        def f1(self):
            print("c")
    
    class d(a):
        def f1(self):
            print("d")
    
    class e(d):
        def f1(self):
            print("e")
    
    class f(a):
        def f1(self):
            print("f")
    
    class g(f):
        def f1(self):
            print("g")
    
    class zx(c,e,g):
        def f1(self):
            print("zx")
    
    wl=zx()
    wl.f1()
    print(zx.__mro__)
    


    zx
    (<class 'main.zx'>, <class 'main.c'>, <class 'main.b'>, <class 'main.a'>, <class 'main.e'>, <class 'main.f'>, <class 'main.d'>, <class 'object'>)

    class a:
        def f1(self):
            print("a")
    
    class b(a):
        def f1(self):
            print("b")
    
    class c(b):
        def f1(self):
            print("c")
    
    class d:
        def f1(self):
            print("d")
    
    class e(d):
        def f1(self):
            print("e")
    
    class f(d):
        def f1(self):
            print("f")
    
    
    class zx(c,e,f):
        def f1(self):
            print("zx")
    
    wl=zx()
    wl.f1()
    print(zx.__mro__)
    

    (<class 'main.zx'>, <class 'main.b'>, <class 'main.c'>, <class 'main.a'>, <class 'main.h'>, <class 'main.f'>, <class 'main.i'>, <class 'main.g'>, <class 'main.e'>, <class 'main.d'>, <class 'object'>)

    class a:
        def f1(self):
            print("a")
    
    class b(a):
        def f1(self):
            print("b")
    
    class c(a):
        def f1(self):
            print("c")
    
    class d:
        def f1(self):
            print("d")
    
    class e(d):
        def f1(self):
            print("e")
    
    class f(d):
        def f1(self):
            print("f")
    
    class g(e):
        def f1(self):
            print("g")
    
    class h(f):
        def f1(self):
            print("h")
    
    class i(g):
        def f1(self):
            print("i")
    
    class zx(b,c,h,i):
        def f1(self):
            print("zx")
    
    wl=zx()
    wl.f1()
    print(zx.__mro__)
    

    简单的线性继承还是有规律可循的,总结来说就是解菱形,如果分支不含菱形就直接找到-1层,等待其他分支来找obj,因为最终各条线路的终点肯定是obj

  • 相关阅读:
    10-vue自定义指令
    09-vue过滤器的基本使用
    vue总结
    07-vue的v-if和v-show
    06-循环数组v-for
    Java通过JNA调用dll或so
    Centos7安装FRP内网穿透工具进行远程连接
    centos7检查Java项目存活与否并重启
    centos7中Java项目重启
    Ubuntu 19.04: Connect to GNOME desktop environment via XRDP
  • 原文地址:https://www.cnblogs.com/zx125/p/11419972.html
Copyright © 2011-2022 走看看