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)>>> a322>>> b = Angle(488)>>> b488
为什么这会发生?代码对我来说似乎微不足道,但也许我只是遗漏了一些非常明显的东西.
解决方法 对于像int这样的不可变类,你应该重写__new__class Angle(int): def __new__(cls,val): val %= 360 inst = super(Angle,cls).__new__(cls,val) return inst
有关详细信息,请参阅python datamodel
总结以上是内存溢出为你收集整理的在python中调用int的__init__看似微不足道的问题全部内容,希望文章能够帮你解决在python中调用int的__init__看似微不足道的问题所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)