今天做数据统计时,需要做大量的测试数据时用到了range(1, 10000000),

运行结果:

 

本想通过设置脚本内存大小来调整。但是想为什么消耗这么大的内存呢,

查看官方手册:

标准的 range() 函数需要在内存中生成一个数组包含每一个在它范围内的值,然后返回该数组, 结果就是会产生多个很大的数组。 比如,调用 range(0, 1000000) 将导致内存占用超过 100 MB。

原来如此,官方提供了一种迭代器的方式来解决这个问题。

做为一种替代方法, 我们可以实现一个 xrange() 生成器, 只需要足够的内存来创建 Iterator 对象并在内部跟踪生成器的当前状态,这样只需要不到1K字节的内存。

 

这样就不报错内存不足,并且性能也好。