python如何清空数组?

我有一个变量数组,可能要大量重复使用,所以每次都要清空,用arr=[],是不是良策?

阅读 39.4k
6 个回答

几种操作方式,效率差不多:

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这门语言。

所以我觉得对于一门动态语言来说,如何将自己的思维从编译语言当中切换过来,是需要好好思考一下的。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题