更新:刚刚看到你的帖子中的call_user_func_array的引用。那不一样。使用getattr获取函数对象,然后使用参数调用它
class A(object):
def method1(self, a, b, c):
# foo
methodname = 'method1'
method = getattr(A, methodname)
方法现在是一个实际的函数对象。你可以直接调用(函数是python中的第一类对象,就像在PHP> 5.3中一样)。但下面的考虑仍然适用。也就是说,上面的例子将会爆炸,除非您使用下面讨论的两个装饰器之一来装饰A.method1,将A的实例作为第一个参数传递,或者将getattr应用于A的实例。
a = A()
method = getattr(a, methodname)
method(1, 2)
你有三个选择
>使用A的实例调用method1(使用两种可能的形式)
>将classmethod装饰器应用于method1:您将无法再在method1中引用self,但是在这种情况下,您将会在其位置传递一个cls实例。
>将staticmethod装饰器应用于method1:您将无法再在staticmethod1中引用self或cls,但是您可以对A引用进行硬编码,但显然这些引用将被A的所有子类继承,除非它们专门覆盖method1不要叫超级。
一些例子:
class Test1(object): # always inherit from object in 2.x. it's called new-style cl