我有一个变量数组,可能要大量重复使用,所以每次都要清空,用arr=[],是不是良策?
几种操作方式,效率差不多:
In [4]: %timeit l=range(10000);l=[];
10000 loops, best of 3: 115 µs per loop
In [5]: %timeit l=range(10000);del l[:]
10000 loops, best of 3: 107 µs per loop
In [6]: %timeit l=range(10000);l=None;
10000 loops, best of 3: 114 µs per loop
所以从性能上来看,这几种删除方式都可以。
从功能上来讲,有一点区别:
1. l=[]和l=None是给l赋一个新的值,不影响原来数组的内容
In [1]: l=range(5)
In [2]: l2=l
In [3]: l2=None
In [4]: l
Out[4]: [0, 1, 2, 3, 4]
2. del l[:]则是删除了原数组的所有元素
In [5]: l2=l
In [6]: del l2[:]
In [7]: l
Out[7]: []
因为python的所有的变量都是指针所以不需要考虑是否del的问题,每次对arr重新赋值后,之前内存的引用计数器会减1。当引用计数器为0时内存会自动回收。
del list[:]
list=[]
list[:]=[]
能贴代码的上下文吗
我一般huge_list = None
如果你确实需要用到list,一般是按你这样处理,以前的list对象会被gc自动回收
我的建议是直接
arr=[]
,如果数量很多的话,这样可以节省一些时间的,因为省去了对对象的操作。
首先我感觉你是带有一种C的思维来思考Python这种动态语言,我虽然不是专业些Python的,但是我曾经较为深入的学习过javascript这门语言。
所以我觉得对于一门动态语言来说,如何将自己的思维从编译语言当中切换过来,是需要好好思考一下的。