对于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/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值