Python 3.x 中的Super() 魔法
在Python 3.x 中,super() 函數擁有一個獨特的能力:可以在沒有任何參數的情況下呼叫。這種行為雖然一開始令人驚訝,但卻源自於為解決常見程式設計陷阱而刻意設計的選擇。
避免DRY 違規和類別名稱歧義
Python 3 之前的版本.x 中,呼叫super() 時需要對類別進行明確命名,如下程式碼片段所示:
<code class="python">class Foo(Bar): def baz(self): return super(Foo, self).baz() + 42</code>
但是,這種做法違反了DRY 原則,容易受到以下原因導致的類別名稱歧義:全局重新綁定或類別裝飾器。為了緩解這些問題,Python 3.x 引入了 super() 的神奇實作。
利用 Class 單元進行運行時解析
The super() 目前實作使用 class 單元。該單元提供對原始類別物件的訪問,使 super() 能夠在運行時解析超類,而無需顯式類別命名。因此,即使重新分配Foo,以下程式碼也能按預期工作:
<code class="python">class Foo(Bar): def baz(self): return super().baz() + 42 Spam = Foo Foo = something_else() Spam().baz() # still works</code>
妥協和實現細節
最初, super() 被提議為一個關鍵字,但由於擔心它被認為“太神奇”,導致了當前的實施。 Guido van Rossum 本人也意識到對 super() 使用不同名稱可能會產生歧義。
潛在缺點
雖然 super() 的神奇行為通常是有益的,如果動態修改超類或重命名 super(),可能會導致意外結果。在這種情況下,建議在方法中明確引用 class 變數以確保正確的功能。
受重新命名影響的函數的替代範例
其他可能受重命名影響的Python 函數和方法包括:
以上是在沒有任何參數的情況下,「super()」如何在 Python 3.x 中發揮其魔力?的詳細內容。更多資訊請關注PHP中文網其他相關文章!