对于python 经典类与新式类的继承的理解

例子1:

点击(此处)折叠或打开

  1. class a:
  2.     def p(self):
  3.         print "aaaaaaaaaaaa"
  4. class b(a):
  5.     pass
  6. class c(a):
  7.     def p(self):
  8.         print "cccccccccccc"
  9. class d(b,c):
  10.     pass

  11. D = d()
  12. D.p()
  13. #结果是 aaaaaaaaaaa
例子2:

点击(此处)折叠或打开

  1. class a:
  2.     def p(self):
  3.         print "aaaaaaaaaaaa"
  4. class b(a):
  5.     pass
  6. class c(a):
  7.     def p(self):
  8.         print "cccccccccccc"
  9. class d(c,b):
  10.     pass

  11. D = d()
  12. D.p()
  13. #结果是 cccccccccccc
例子3:

点击(此处)折叠或打开

  1. class a:
  2.     pass
  3. class b(a):
  4.     pass
  5. class c(a):
  6.     def p(self):
  7.         print "cccccccccccc"
  8. class d(b,c):
  9.     pass

  10. D = d()
  11. D.p()
  12. #结果是 cccccccccccc
结论:由上可知,对应未继承object的经典类,实例查找方法采用的是深度优先思想。
如上例子所示,D的p方法先找d本身是否有该方法,若没有则往上找第一个父类是否有该方法,若没有再往上找第一个父类是否有该方法,直到根。
若都没有,则从第二个父类一直找到根。

例子4:

点击(此处)折叠或打开

  1. class a(object):
  2.     def p(self):
  3.         print "aaaaaaaaaaaa"
  4. class b(a):
  5.     pass
  6. class c(a):
  7.     def p(self):
  8.         print "cccccccccccc"
  9. class d(b,c):
  10.     pass

  11. D = d()
  12. D.p()
  13. #结果是 cccccccccccc

结论:对于继承自object的新式类,实例查找方法采用的是广度优先思想。
如上例子所示,D的p方法先找d本身是否有该方法,若没有则往上找第一个父类是否有该方法,若没有则找同级其他父类是否有该方法,搜索完同级再搜索更上一级的父类,直到根。


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31441616/viewspace-2152841/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31441616/viewspace-2152841/

你可能感兴趣的:(python)