(下面都是我个人的理解,不严谨啊)
按照传统c++的思路:
class A {
void foo(int) ...
得到的程序里foo是个函数,其代码放在内存1234位置,调用该函数时就jmp 1234;内部使用this时该指针指向一个对象,此时对象与1234处的代码块无关(重点是这个“无关”)。
但是python里不是这样子的:
class A
def foo(self ...
人眼看到的貌似可以执行的函数foo在解释器眼里是一段desc,解释了当需要执行此段脚本时需要干什么。
当生成一个对象a时,解释器根据对foo的描述,生成一个“真的函数” bound method,作为a的一个方法,这个方法是callable的。(不过这个只是“逻辑生成”,真正跑的代码不会每个__dict__都包含所有的属性方法)
换个说法的话,def foo这个def本身可以视为没有__call__能力,不callable。通过这个def,解释器自动生成了一个obj,其中obj.__call__执行了def定义的脚本内容,这个obj“被叫成foo给人看”,然后这个obj(在逻辑上)绑定到对象上,在对象点操作时(在逻辑上)从__dict__中拿到它(即obj,而不是def)
比如:
class A(object):
def foo(self):
print("original")
def foo(self):
print("tmp")
a = A()
b = A()
b.foo = types.MethodType(foo, b)
a.foo()
b.foo()
print(a.foo)
print(b.foo)
print(a.__dict__)
print(b.__dict__)
至于partial和partialmethod,则是一个生成callable,一个生成desc。当解释器看到desc时,就根据描述符协议生成“人类函数”,类似前面说的def生成obj。
比如:
class A(object):
def foo(self, a):
return a
foo2 = partialmethod(foo, 2)
a = A()
print(A.foo2)
print(a.foo2)
【 在 JulyClyde 的大作中提到: 】
: 函数本身并不是callable??啊?这个咋理解?
A: 问题是:它其实是callable啊
: 象
: ...................
--
FROM 114.246.237.*