十进制Python与浮点运行时

关于在使用这两种不同数据类型之间我应该期待什么样的运行时差异的一般问题.

我的测试:

test = [100.0897463, 1.099999939393,1.37382829829393,29.1937462874847272,2.095478262874647474]
test2 = [decimal.Decimal('100.0897463'), decimal.Decimal('1.09999993939'), decimal.Decimal('1.37382829829'), decimal.Decimal('29.1937462875'), decimal.Decimal('2.09547826287')]

def average(numbers, ddof=0):
    return sum(numbers) / (len(numbers)-ddof)

%timeit average(test)
%timeit average(test2)

运行时的差异是:
1000000个循环,最佳3:364 ns每个循环
10000个循环,最佳3:每循环80.3μs

所以使用十进制比使用浮点数慢大约200倍.在确定使用哪种数据类型时,这种差异是否正常并且与我期望的一致?

最佳答案
根据您看到的时差,您可能正在使用Python 2.x.在Python 2.x中,十进制模块是用Python编写的,而且速度很慢.从Python 3.2开始,十进制模块被重写为C并且速度更快.

在我的系统上使用Python 2.7,十进制模块慢了大约180倍.使用Python 3.5,十进制模块的速度只有2.5倍.

如果你关心十进制性能,Python 3要快得多.

转载注明原文:十进制Python与浮点运行时 - 代码日志