代码不能像最初编写的那样工作的原因是不能在实例中定义魔术方法。根据docs:For custom classes, implicit invocations of special methods are only guaranteed to work correctly if defined on an object’s type, not in the object’s instance dictionary.
用@classmethod装饰您的魔术方法,这有助于将通过__get__获得的绑定方法分配给一个实例。在这两种情况下,Python都会忽略类中未定义的任何描述符。在
这也是-Positive() is Negative起作用的原因。当您否定Positive的实例时,解释器在类中查找__neg__。在这里用@classmethod装饰是完全多余的,因为您无论如何都忽略了输入参数。但现在有一个神奇的方法返回一个对象。在
要在类对象上正确定义一个魔术方法,需要在元类上定义它:class MetaPositive(type):
def __neg__(self):
return Negative
class Negative: pass
class Positive(metaclass=MetaPositive): pass
有趣的是,这并不局限于一元运算符。您可以在元类上定义任何dunder方法,并让您的类支持相应的操作:
^{pr2}$
现在可以使用>运算符来比较类。我并不是暗示你应该做那样的事,但可能性肯定存在。在
问题仍然存在,就像它经常发生的那样,为什么你会想做这样的事情首先。在
本文发布于:2024-01-29 16:14:08,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170651605216509.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |