首頁 >後端開發 >Python教學 >為什麼 Python 方法在引用相等性方面與函數相比表現不同?

為什麼 Python 方法在引用相等性方面與函數相比表現不同?

Linda Hamilton
Linda Hamilton原創
2024-10-30 07:32:02540瀏覽

 Why Do Python Methods Behave Differently in Reference Equality Compared to Functions?

揭開謎團: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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn