我很想知道直接比较和在数组中进行检查之间的时间区别是什么。在
结论:构建阵列的成本不是免费的,在考虑速度差异时必须考虑。
如果数组是在比较时构造的,它在技术上比简单比较慢。所以简单的比较会更快地进入或退出循环。在
也就是说,如果数组已经构造好了,那么在一个大循环中签入数组比进行简单的比较要快。在$ speed.py
inarray x 1000000: 0.277590343844
comparison x 1000000: 0.347808290754
makearray x 1000000: 0.408771123295
^{pr2}$
这并不能很好地回答您为什么不经常在中看到比较使用的问题。我是在猜测,但它很可能是1,2,4和作者需要编写特定代码的情况的混合。在
我个人根据情况使用过这两种方法。选择通常归结为速度或简单。在
编辑:
@bracco23是对的,使用元组vs数组vs list会改变计时。在$ speed.py
inarray x 1000000: 0.260784980761
intuple x 1000000: 0.288696420718
inlist x 1000000: 0.311479982167
maketuple x 1000000: 0.356532747578
comparison x 1000000: 0.360010093964
makearray x 1000000: 0.41094386108
makelist x 1000000: 0.433603059099