python3 多继承搜索__init__方法的两种策略
繼承情形一:
測(cè)試代碼如下:
class A(object):def __init__(self):print('A')class B(object):def __init__(self):print('B')class C(A):def __init__(self):print('C')class D(B): def __init__(self):print('D')class E(C, D):pass執(zhí)行當(dāng)前代碼 x=E(),打印輸出為:C;說(shuō)明在E類中不存在init方法的時(shí)候,先找C中的init方法;
修改代碼,去掉C類中的init方法,修改后,的代碼如下
class A(object):def __init__(self):print('A')class B(object):def __init__(self):print('B')class C(A):passclass D(B): def __init__(self):print('D')class E(C, D):pass再次執(zhí)行當(dāng)前代碼 x=E(),輸出結(jié)果為A,然后刪除掉A中的init方法,修改后的代碼如下:
class A(object):passclass B(object):def __init__(self):print('B')class C(A):passclass D(B): def __init__(self):print('D')class E(C, D):pass執(zhí)行x=E();輸出結(jié)果為D,然后刪除D類中的init方法后,代碼如下:
class A(object):passclass B(object):def __init__(self):print('B')class C(A):passclass D(B): passclass E(C, D):pass運(yùn)行 x =E();輸出結(jié)果為B。
可見(jiàn)在這種情形下,python3搜索__init__方法的順序是 E->C->A->D->B
繼承情形二:
在這種集成情況下,類的初始化情況如下:
class A(object):def __init__(self):print('A')class C(A):def __init__(self):print('C')class D(A): def __init__(self):print('D')class E(C, D):pass運(yùn)行 x = E();輸出結(jié)果為C,去掉類C中的init方法,代碼結(jié)構(gòu)如下:
class A(object):def __init__(self):print('A')class C(A):passclass D(A): def __init__(self):print('D')class E(C, D):pass運(yùn)行 x=E();輸出結(jié)果為D,去掉類D中的init方法,代碼結(jié)構(gòu)如下:
class A(object):def __init__(self):print('A')class C(A):passclass D(A): passclass E(C, D):pass輸出結(jié)果為A,可見(jiàn)在這種情況下python3搜索__init__方法的順序是 E->C->D->A
總結(jié):在兩種不同的繼承結(jié)構(gòu)下,python3使用了不同的init方法的搜索策略。需要注意起來(lái)!
總結(jié)
以上是生活随笔為你收集整理的python3 多继承搜索__init__方法的两种策略的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Git Bash中npm配置,加速下载等
- 下一篇: 远古VOD存在严重注入漏洞!!