自我属性存在于功能指针中?

时间:2018-04-24 21:15:33

标签: python python-3.4

假设我有一个简单的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定义)?

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

1 个答案:

答案 0 :(得分:1)

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