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__被寻求时,它们都没有真正起作用.我想这里的特殊方法太特别了.我目前唯一的解决方案是手动委派我能想到的每一种特殊方法,但肯定必须有更好的方法.有任何想法吗?
愚蠢的我。现在可以了。如果有人想知道如何做,这里是:
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__