#! /usr/bin/python
# -*- coding:utf-8 -*-
class P1():
? def foo(self):
? ? print 'p1-foo'
class P2():
? def foo(self):
? ? print 'p2-foo'
? def bar(self):
? ? print 'p2-bar'
class C1(P1,P2):
? pass
class C2(P1,P2):
? def bar(self):
? ? print 'C2-bar'
class D(C1,C2):
? pass
if __name__ =='__main__':
? d=D()
? d.foo()
? d.bar()
執(zhí)行的結(jié)果:
p1-foo
p2-bar
將代碼實(shí)例倘潜,畫了一個(gè)圖,方便理解:
從上面經(jīng)典類的輸出結(jié)果來看志于,
實(shí)例d調(diào)用foo()時(shí)涮因,搜索順序是 D => C1 => P1,
實(shí)例d調(diào)用bar()時(shí)伺绽,搜索順序是 D => C1 => P1 => P2
總結(jié):經(jīng)典類的搜索方式是按照“從左至右养泡,深度優(yōu)先”的方式去查找屬性。d先查找自身是否有foo方法奈应,沒有則查找最近的父類C1里是否有該方法澜掩,如果沒有則繼續(xù)向上查找,直到在P1中找到該方法杖挣,查找結(jié)束肩榕。