在 Python 3.x 中,我可以用 bar()
做什么而不能用 foo()
做什么?
class A:
def foo():
print("some code")
@staticmethod
def bar():
print("some code")
注意:我最初忘记将 self
指定为 foo()
的参数,但我将错误留在那里,因为答案和解决.
最佳答案
staticmethod
是一种不需要对象作为其第一个参数的方法。这意味着它是一种对类本身及其所有实例化有用的方法,而不仅仅是它的实例(对象初始化为 A()
。
这实际上意味着 Python 不会隐式地将对象本身作为参数发送。一旦你调用它,你的第一个方法就会中断:
>>> a.foo()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: foo() takes 0 positional arguments but 1 was given
这是因为 Python 提供对象方法,对象本身作为第一个参数。因此无处不在的 self 论点:
def foo(self): #Proper signature
另一方面,
A.bar()
会很好地工作,所以会
a.bar()
该对象未作为第一个参数提供。将 staticmethod
用于应该对类及其实例有帮助但不需要任何知识的方法。通常我将它们用作实用函数。
请注意还有第三个版本,一个classmethod
,它类似于常规方法,因为它默认接受第一个参数 - 调用者的类。在这种情况下,最小签名是
@classmethod
def operateOnClass(cls):
使用它来进行影响所有实例的更改,例如更改类变量。
关于python - 有@staticmethod 和没有它的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55274799/