我理解的MRO
2019-04-25 本文已影响0人
粟米一粒
定义: Method Resolution Order
从字面的意思理解是就是解决function
执行的顺序,python2.3之后使用C3 算法来生成 MRO
典型用途:super()
C3 算法:http://blog.sina.com.cn/s/blog_45ac0d0a01018488.html(个人感觉比较易懂的一个)
C3 算法个人理解: 类似一张族谱(左侧比右侧的辈分小,上面的比下面的小),得到这个人的所有辈分从小到大的一个列表(不可以出现A是B的祖先,B又是A的祖先的情况)。
C3 算法实现(个人版):深度优先遍历,得到列表,重复的元素取列表里面最后一个元素(需要一个正确的继承关系);
super: 按照 MRO
列表执行对应object
的函数。
说明: 纯个人理解有错误的地方欢迎指正(已看过一些资料)。