dir()当我注意到这个时,我正在使用内置函数:
>>> dir(type)
['__abstractmethods__', '__base__', '__bases__', '__basicsize__', '__call__', '__class__', '__delattr__', '__dict__', '__dictoffset__', '__dir__', '__doc__', '__eq__', '__flags__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__instancecheck__', '__itemsize__', '__le__', '__lt__', '__module__', '__mro__', '__name__', '__ne__', '__new__', '__prepare__', '__qualname__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasscheck__', '__subclasses__', '__subclasshook__', '__text_signature__', '__weakrefoffset__', 'mro']
>>> type.__abstractmethods__
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: __abstractmethods__
>>> list.__abstractmethods__
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: __abstractmethods__
Run Code Online (Sandbox Code Playgroud)
我不明白,它出现在列表中,为什么我会收到这样的错误?
__abstractmethods__是支持抽象基类的描述符;它包装了一个默认为空的插槽(因此描述符引发属性错误)。最重要的是,它是 CPython 如何处理抽象方法的实现细节。
该属性用于跟踪哪些方法是抽象的,以便在不提供具体实现的情况下可以阻止创建实例:
>>> import abc
>>> class FooABC(metaclass=abc.ABCMeta):
... @abc.abstractmethod
... def bar(self):
... pass
...
>>> FooABC.__abstractmethods__
frozenset({'bar'})
>>> class Foo(FooABC): pass
...
>>> Foo()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: Can't instantiate abstract class Foo with abstract methods bar
Run Code Online (Sandbox Code Playgroud)
在abc.ABCMeta执行设置__abstractmethods__属性,并type()用它来检查应该已经执行,但都没有任何抽象方法。
| 归档时间: |
|
| 查看次数: |
1235 次 |
| 最近记录: |