【问题标题】:Seemingly trivial issue calling int's __init__ in python在 python 中调用 int 的 __init__ 看似微不足道的问题
【发布时间】:2014-02-22 21:16:07
【问题描述】:

观察以下代码:

class Angle(int):
    """Basic Angle object: Angle(number)"""

    def __init__(self, angle):
        angle %= 360
        super(Angle, self).__init__(angle)

相当简单的东西,Angle 基本上只是一个不会超过 360 或低于 0 的int。这个__init__ 只是确保输入角度与前面列出的条件匹配。但由于某种原因,上面的代码给了我以下输出:

>>> a = Angle(322)
>>> a
322
>>> b = Angle(488)
>>> b
488

到底为什么会发生这种情况?代码对我来说似乎微不足道,但也许我只是遗漏了一些非常明显的东西。

【问题讨论】:

标签: python class inheritance


【解决方案1】:

对于像 int 这样的不可变类,您应该覆盖 __new__

class Angle(int):
  def __new__(cls, val):
    val %= 360
    inst = super(Angle, cls).__new__(cls, val)
    return inst

查看python datamodel了解更多信息

【讨论】:

    【解决方案2】:

    咨询newpython的对象接口方法。

    __new__() 主要用于允许不可变类型(如 int、str 或 tuple)的子类自定义实例创建。也是 通常在自定义元类中被覆盖以自定义类 创作。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2010-12-11
      • 1970-01-01
      • 1970-01-01
      • 2015-04-20
      • 2012-08-31
      • 1970-01-01
      • 2020-11-25
      相关资源
      最近更新 更多