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中文網其他相關文章!