首页 > 解决方案 > 自属性存在于函数指针中?

问题描述

假设我有一个简单的 python3 类,如下所示:

class Test():
    def __init__(self):
        self.a = 'a'
    def checkIsA(self, checkA):
        return self.a == checkA

还有一些进一步的代码,例如:

def tester(func, item):
    return func(item)

testObject = Test()
print(tester(testObject.checkIsA, 'a'))  # prints True

当另一个函数独立使用时,函数指针(?) checkIsA 如何仍然知道它的类成员变量(由 self 定义)?

我想在我正在编写的程序中使用这个功能,但我担心我没有正确理解这些语义。

标签: pythonpython-3.4

解决方案


testObject.checkIsA是所谓的绑定方法——它会记住它所取自的实例,以便它的self属性由该实例自动填充。

您可以轻松检查类函数(未绑定方法)和实例方法(绑定方法)之间的区别,Python 会很高兴地告诉您所有细节:

testObject = Test()

print(Test.checkIsA)        # <function Test.checkIsA at 0x00000000041236A8>
print(testObject.checkIsA)  # <bound method Test.checkIsA of
                            # <__main__.Test object at 0x0000000004109390>>

您也可以通过传递您的实例来模拟testObject.checkIsA()直接通过未绑定Test.checkIsA函数的调用,例如:

def tester(func, instance, item):
    return func(instance, item)

testObject = Test()
print(tester(Test.checkIsA, testObject, 'a'))  # prints True

或者,使用functools.partial

import functools

def tester(func, item):
    return func(item)

testObject = Test()
print(tester(functools.partial(Test.checkIsA, testObject), 'a'))  # prints True

这正是绑定实例方法在后面为您所做的,它通过self使用其存储的__self__值来补充第一个属性。你也可以检查一下:

testObject = Test()
print(testObject.checkIsA.__self__ is testObject)  # True

推荐阅读