例子1:
例子2:
例子3:
结论:由上可知,对应未继承object的经典类,实例查找方法采用的是深度优先思想。
如上例子所示,D的p方法先找d本身是否有该方法,若没有则往上找第一个父类是否有该方法,若没有再往上找第一个父类是否有该方法,直到根。
若都没有,则从第二个父类一直找到根。
例子4:
结论:对于继承自object的新式类,实例查找方法采用的是广度优先思想。
如上例子所示,D的p方法先找d本身是否有该方法,若没有则往上找第一个父类是否有该方法,若没有则找同级其他父类是否有该方法,搜索完同级再搜索更上一级的父类,直到根。
点击(此处)折叠或打开
- class a:
- def p(self):
- print "aaaaaaaaaaaa"
- class b(a):
- pass
- class c(a):
- def p(self):
- print "cccccccccccc"
- class d(b,c):
- pass
-
- D = d()
- D.p()
- #结果是 aaaaaaaaaaa
点击(此处)折叠或打开
- class a:
- def p(self):
- print "aaaaaaaaaaaa"
- class b(a):
- pass
- class c(a):
- def p(self):
- print "cccccccccccc"
- class d(c,b):
- pass
-
- D = d()
- D.p()
- #结果是 cccccccccccc
点击(此处)折叠或打开
- class a:
- pass
- class b(a):
- pass
- class c(a):
- def p(self):
- print "cccccccccccc"
- class d(b,c):
- pass
-
- D = d()
- D.p()
- #结果是 cccccccccccc
如上例子所示,D的p方法先找d本身是否有该方法,若没有则往上找第一个父类是否有该方法,若没有再往上找第一个父类是否有该方法,直到根。
若都没有,则从第二个父类一直找到根。
例子4:
点击(此处)折叠或打开
- class a(object):
- def p(self):
- print "aaaaaaaaaaaa"
- class b(a):
- pass
- class c(a):
- def p(self):
- print "cccccccccccc"
- class d(b,c):
- pass
-
- D = d()
- D.p()
- #结果是 cccccccccccc
结论:对于继承自object的新式类,实例查找方法采用的是广度优先思想。
如上例子所示,D的p方法先找d本身是否有该方法,若没有则往上找第一个父类是否有该方法,若没有则找同级其他父类是否有该方法,搜索完同级再搜索更上一级的父类,直到根。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31441616/viewspace-2152841/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/31441616/viewspace-2152841/