我正在尝试不同的东西来理解Python中的装饰器和函数。 以下代码是否正确:
import math
def calculate_area(func):
def area(a,b):
return a+b
return area
class Donut():
def __init__(self, outer, inner):
self.inner = inner
self.outer = outer
@calculate_area
@staticmethod
def area(self):
outer, inner = self.radius, self.inner
return Circle(outer).area() - Circle(inner).area()
“staticmenthod”装饰器会告诉内置的默认元类类型(类的类,参见这个问题)不创建绑定方法吗? 有可能做到:
Donut.area(4,5)
Traceback (most recent call last):
File "<pyshell#33>", line 1, in <module>
Donut.area(4,5)
TypeError: unbound method area() must be called with Donut instance as first argument (got int instance instead)
请帮助我理解绑定方法和未绑定方法以及装饰器对它们的影响。
答案 0 :(得分:2)
将@staticmethod与你的装饰者交换
import math
def calculate_area(func):
def _area(a, b):
return a + b
return _area
class Donut():
def __init__(self, outer, inner):
self.inner = inner
self.outer = outer
@staticmethod
@calculate_area
def area(cls):
outer, inner = self.radius, self.inner
return ""
编辑1:
python interpreter需要在另一个装饰器之前添加@staticmethod,因为在创建类类型之前,需要确定类成员和实例成员。如果你的第一个装饰器是其他任何东西,解释器将此函数称为实例成员。见this
编辑2:
建议使用@classmethod代替@staticmethod,有关详细信息,请参阅this