首頁 >後端開發 >Python教學 >為什麼 Python 中的方法缺乏引用相等性?

為什麼 Python 中的方法缺乏引用相等性?

DDD
DDD原創
2024-10-27 15:53:02549瀏覽

 Why Do Methods in Python Lack Reference Equality?

Python 中的方法引用相等:揭開神秘面紗

為什麼看似從常規函數繼承而來的方法卻缺乏引用的美德平等?這種令人費解的現象讓許多Python程式設計師感到困惑。讓我們深入研究底層機制,以了解這種差異背後的原因。

與在整個程式中保存其物件標識的常規函數不同,方法物件是在存取時動態建立的。這種短暫的性質源自於它們對描述符的依賴,描述符在呼叫 .__get__ 方法時產生方法物件。程式碼片段恰當地說明了這種行為:

<code class="python">>>> What.__dict__['meth']
<function What.meth at 0x10a6f9c80>
>>> What.__dict__['meth'].__get__(What(), What)
<bound method What.meth of <__main__.What object at 0x10a6f7b10>></code>

從 Python 3.8 開始,方法的相等性測試變得一致且可預測。如果兩個方法的 .__self__ (它們綁定到的實例)和 .__func__ (底層函數)屬性是相同的對象,則它們被認為是相等的。

但是,這種一致的行為是最近才加入的。在 Python 3.8 之前,方法相等性因其實作細節而異。對於 Python 方法和某些 C 方法類型,self 進行相等性比較,而對於其他 C 方法類型,self 以同一性進行比較。這種不一致最終在 Python 問題 1617161 中得到解決。

為了確保一致性,建議使用其func 屬性來驗證方法身份:

<code class="python">>>> What.meth == What.meth     # functions (or unbound methods in Python 2)
True
>>> What().meth == What.meth   # bound method and function
False
>>> What().meth == What().meth # bound methods with *different* instances
False
>>> What().meth.__func__ == What().meth.__func__ # functions
True</code>

總而言之,方法對象的短暫性,加上方法相等性的歷史不一致,導致方法缺乏引用相等性。然而,Python 3.8 引入了一種更一致且可預測的方法,使程式設計師能夠更有信心地推理方法相等性。

以上是為什麼 Python 中的方法缺乏引用相等性?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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