揭开谜团: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中文网其他相关文章!