我正在查看一些复杂的Python 2.6代码,偶尔会导致生成无穷大(至少有一个无穷大被json库序列化 - 它会检查w / math.isinf)。
特别令人困惑的是,Python(据我所知)不应该能够将计算结果设置为无穷大。我错了这个假设吗?我知道你只能从常数得到无穷大:
k = float('inf')
k = 1e900
答案 0 :(得分:13)
在1e308和1e309之间,浮点数精度不高,所以如果你计算的结果超出了这个范围,你会看到inf
>>> 1e308
1e+308
>>> 1e309
inf
>>> json.dumps(1e308,allow_nan=False)
'1e+308'
>>> json.dumps(1e309,allow_nan=False)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.6/json/__init__.py", line 237, in dumps
**kw).encode(obj)
File "/usr/lib/python2.6/json/encoder.py", line 367, in encode
chunks = list(self.iterencode(o))
File "/usr/lib/python2.6/json/encoder.py", line 304, in _iterencode
yield floatstr(o, self.allow_nan)
File "/usr/lib/python2.6/json/encoder.py", line 47, in floatstr
raise ValueError(msg)
ValueError: Out of range float values are not JSON compliant: inf
>>>
Decimal可以处理更大的数字,但显然会有性能损失(并且不能用json序列化)
>>> from decimal import Decimal
>>> Decimal('1e900')/10
Decimal("1E+899")
以下是不会引发溢出异常的添加示例
>>> a=1e308
>>> a+a
inf