我总是在Python中听到这个声明(对于诸如装饰器之类的主题,当你传递函数时等)但是从未真正看到过这方面的细节.
例如,是否可以创建一个只有一个抽象方法的类c,该方法使用一组打开和关闭的括号进行调用.
i.e class c:
@abstractmethod
def method_to_be_called_by():
...
所以你可以拥有
c(whatever parameters are required)
凭借我的理解,我可能会脱离标记,我只是对这个人的意思感到好奇.
解决方法:
您正在寻找__call__ method.函数对象具有以下方法:
>>> def foo(): pass
...
>>> foo.__call__
并不是Python解释器循环在遇到Python函数对象时实际上使用了该方法;在大多数情况下,实现中的优化直接跳转到包含的字节码.
但您可以在自己的自定义类中使用它:
class Callable(object):
def __init__(self, name):
self.name = name
def __call__(self, greeting):
return '{}, {}!'.format(greeting, self.name)
演示:
>>> class Callable(object):
... def __init__(self, name):
... self.name = name
... def __call__(self, greeting):
... return '{}, {}!'.format(greeting, self.name)
...
>>> Callable('World')('Hello')
'Hello, World!'
>>> def foo(): pass
...
>>> foo
>>> lambda: None
at 0x106d90668>
您可以将其与使用文字语法创建字符串或整数或列表进行比较:
listobject = [1, 'two']
上面创建了3个对象而没有调用类型,Python根据所使用的语法为您完成了所有这些操作.这同样适用于功能.
自己创造一个可能会更复杂;您需要拥有一个代码对象并引用一个全局命名空间,至少:
>>> function_type = type(lambda: None)
>>> function_type
>>> function_type(foo.__code__, globals(), 'bar')
这里我通过重用函数类型创建了一个函数对象,从foo函数中获取代码对象;函数类型不是内置名称,但类型确实存在,可以通过在现有函数实例上调用type()来获取.
我还传入了我的解释器的全局命名空间和一个名字;后者是一个可选的论点;否则从代码对象中获取名称.
标签:python,class,function,methods
来源: https://codeday.me/bug/20190926/1822267.html