python中super關鍵字的用法


http://python.jobbole.com/86787/

 

class A:
def __init__(self):
   print "enter A"
   print "leave A"


class B(A):
def __init__(self):
   print "enter B"
   A.__init__(self)   # old method
   print "leave B"


>>> b = B()

enter B
enter A
leave A
leave B

這樣做的缺點是,當一個子類的父類發生變化時(如類B的父類由A變為C時),必須遍歷整個類定義,把所有的通過非綁定的方法的類名全部替換過來.

自Python 2.2開始,Python添加了一個關鍵字super,來解決這個問題。

super(type [, object-or-type])

Return the superclass of type. If the second argument is omitted the super object
returned is unbound. If the second argument is an object, isinstance(obj, type)
must be true. If the second argument is a type, issubclass(type2, type) must be
true. super() only works for new-style classes.

A typical use for calling a cooperative superclass method is:

   class C(B):
       def meth(self, arg):
           super(C, self).meth(arg)

 ----------------------------------------------------------------------------------------------------------------------

class A(object):    # A must be new-style class
  def __init__(self):
        print "enter A"
        print "leave A"

class B(A):
  def __init__(self):
        print "enter B"
            super(B, self).__init__()  # new method
        print "leave B"

 

1. super並不是一個函數,是一個類名,形如super(B, self)事實上調用了super類的初始化函數,產生了一個super對象;
2. super類的初始化函數並沒有做什么特殊的操作,只是簡單記錄了類類型和具體實例;
3. super(B, self).func的調用並不是用於調用當前類的父類的func函數;
4. Python的多繼承類是通過mro的方式來保證各個父類的函數被逐一調用,而且保證每個父類函數只調用一次(如果每個類都使用super);
5. 混用super類和非綁定的函數是一個危險行為,這可能導致應該調用的父類函數沒有調用或者一個父類函數被調用多次。

------------------------------

super 是用來解決多重繼承問題的,直接用類名調用父類方法在使用單繼承的時候沒問題,但是如果使用多繼承,會涉及到查找順序(MRO)、重復調用(鑽石繼承)等種種問題。總之前人留下的經驗就是:保持一致性。要不全部用類名調用父類,要不就全部用 super,不要一半一半。

從運行結果上看,普通繼承和super繼承是一樣的。但是其實它們的內部運行機制不一樣,這一點在多重繼承時體現得很明顯。在super機制里可以保證公共父類僅被執行一次,至於執行的順序,是按照mro進行的(E.__mro__)。
注意super繼承只能用於新式類,用於經典類時就會報錯。
新式類:必須有繼承的類,如果沒什么想繼承的,那就繼承object
經典類:沒有父類,如果此時調用super就會出現錯誤:『super() argument 1 must be type, not classobj』

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM