2

有这个类:

class A(frozenset):
    def __init__(self, *args):
        frozenset.__init__(self, *args)

执行A(range(2))导致以下错误:

Traceback (most recent call last):
  File "<pyshell#65>", line 1, in <module>
    A(range(2))
  File "<pyshell#60>", line 3, in __init__
    frozenset.__init__(self, *args)
TypeError: object.__init__() takes no parameters

同时,frozenset(range(2))有效,如果我继承AsetA(range(2))也有效。

如果我将 0 个或多个参数传递给 A 的构造函数,它会正常工作(使用 0 个参数创建一个空集,使用 2 个或更多参数 raises TypeError: A expected at most 1 arguments, got 2)。

4

1 回答 1

3

实际上,在子类化以从传递的可迭代对象(作为参数)创建新的frozenset时,您需要覆盖__new__方法(不是__init____init__方法将接受由__new__方法生成和返回的实例):frozenset

class A(frozenset):
    def __new__(cls, *args):
        self = super().__new__(cls, *args)
        return self


print(A(range(2)))
print(A(range(2)).__class__.__bases__)

样本输出:

A({0, 1})
(<class 'frozenset'>,)
于 2019-07-17T14:51:23.330 回答