在Python中自定义不可变类型

Vek*_*eky 5 python delegation immutability

假设我想要一个frozenset带有2个元素的自定义,迭代,散列,比较,并具有各种其他不错的操作作为冻结集,但打印方式不同.

>>> p = edge(5, 7)
>>> p == edge(7, 5)
True
>>> p
edge(5, 7)
Run Code Online (Sandbox Code Playgroud)

我可以继承,或者我可以委托,但在任何情况下我都得不到我想要的.

如果我从字面上继承,似乎没有办法可以写__init__,因为我的父母是不可变的.我可以写:

class edge:
    def __new__(cls, a, b):
        return frozenset({a, b})
Run Code Online (Sandbox Code Playgroud)

但后来我得到了一个合适的冷冻集,无法自定义它__repr__,这就是我想要做的.我不能super()以任何好的方式在这里工作.

如果我委托,我可以覆盖__getattr____getattribute__,但是当例如__iter__被寻求时,它们都没有真正起作用.我想这里的特殊方法太特别了.我目前唯一的解决方案是手动委派我能想到的每一种特殊方法,但肯定必须有更好的方法.有任何想法吗?

Vek*_*eky 2

愚蠢的我。现在可以了。如果有人想知道如何做,这里是:

class pair(frozenset):
    def __new__(cls, a, b):
        return super().__new__(cls, {a, b})
    def __repr__(self):
        a, b = sorted(self)
        return "{} & {}".format(a, b)
Run Code Online (Sandbox Code Playgroud)

错误在于,我认为当不带参数调用时,它会以与 相同的方式super().__new__({a, b})改变 my 。当然,隐式类方法并没有帮助。:-)clsself__new__