我有一个奇怪的问题。我有以下代码:
class A:
def f():
return __class__()
class B(A):
pass
a = A.f()
b = B.f()
print(a, b)
输出是这样的:
<__main__.A object at 0x01AF2630> <__main__.A object at 0x01B09B70>
那么我怎样才能获得B
而不是第二个A
?
答案 0 :(得分:7)
为{em>方法上下文设置了magic __class__
closure,并且仅供super()
使用。
对于您想要使用self.__class__
的方法:
return self.__class__()
或者更好的是,使用type(self)
:
return type(self)()
如果您希望能够在类上调用该方法,那么使用classmethod
decorator来提交对类对象的引用,而不是保持未绑定:
@classmethod
def f(cls):
return cls()
classmethod
总是绑定到他们被调用的类,因此对于A.f()
A
,对于B.f()
,你会被提交B
}}