揭開謎團:Python 中的方法引用相等
在 Python 程式設計領域,引用相等的概念既誘人又有趣。令人困惑。令人驚訝的是,與常規函數不同,方法在引用相等性方面表現出獨特的行為。
為什麼會出現這種顯著差異?答案在於方法創建和呼叫方式的本質。與獨立存在於全域範圍內的函數不同,方法是在每次存取時動態產生的。這源自於函數在 Python 中作為描述符的作用。當呼叫函數的 .__get__ 方法時,會傳回一個方法物件。
考慮以下範例:
<code class="python">class What: def meth(self): pass print(What.meth is What.meth) # This is False in Python 2 print(inst.meth is inst.meth) # False</code>
上述程式碼在兩種情況下都會列印 False。這是因為每次造訪 What.meth 都會建立一個新的方法物件。因此,這些方法物件不能被認為是引用相等的。
相反,常規函數是全域實體,因此當呼叫 func 時,它總是引用同一個物件。這解釋了 func 中的 True 結果是 func。
但是,Python 3.8 引入了重大改進。現在,如果兩個方法的 .__self__ 和 .__func__ 屬性是相同的對象,則它們被視為相等。這意味著如果兩個方法包裝相同的函數並綁定到同一個實例,它們將使用 == 來比較 True。
對於 3.8 之前的 Python 版本,方法 == 行為不一致。 Python 方法和一種類型的 C 方法比較 self 是否相等,而另一種類型的 C 方法比較 self 相同。
測試兩個方法是否表示相同底層函數,建議比較它們的 func 屬性:
<code class="python">print(What.meth == What.meth) # functions (or unbound methods in Python 2) print(What().meth == What().meth) # bound methods with *different* instances print(What().meth.__func__ == What().meth.__func__) # functions</code>
以上是為什麼 Python 方法在引用相等性方面與函數相比表現不同?的詳細內容。更多資訊請關注PHP中文網其他相關文章!