(一)Python入门-3序列:03列表-元素的5种添加方式-效率问题

列表元素的增加和删除

  当列表增加和删除元素时,列表会自动进行内存管理,大大减少了程序员的负担。但这 个特点涉及列表元素的大量移动,效率较低。除非必要,我们一般只在列表的尾部添加元素 或删除元素,这会大大提高列表的操作效率。

一:append()方法

  原地修改列表对象,是真正的列表尾部添加新的元素,速度最快,推荐使用。

 1 >>> a = [20,40]
 2       
 3 >>> id(a)
 4       
 5 1983366023560
 6 >>> a.append(80)
 7       
 8 >>> a
 9       
10 [20, 40, 80]
11 >>> id(a)
12       
13 1983366023560

二:+运算符操作

  并不是真正的尾部添加元素,而是创建新的列表对象;将原列表的元素和新列表的元素依次 复制到新的列表对象中。这样,会涉及大量的复制操作,对于操作大量元素不建议使用。

 1 >>> a = [20,40]
 2       
 3 >>> id(a)
 4       
 5 1983365869704
 6 >>> a = a + [50]
 7       
 8 >>> a
 9       
10 [20, 40, 50]
11 >>> id(a)
12       
13 1983366023240

  通过如上测试,我们发现变量a 的地址发生了变化。也就是创建了新的列表对象。

三:extend()方法

  将目标列表的所有元素添加到本列表的尾部,属于原地操作,不创建新的列表对象。

 1 >>> a = [20,40]
 2       
 3 >>> id(a)
 4       
 5 1983358713160
 6 >>> a.extend([60,80])
 7       
 8 >>> a
 9       
10 [20, 40, 60, 80]
11 >>> id(a)
12       
13 1983358713160

四:insert()插入元素

  使用insert()方法可以将指定的元素插入到列表对象的任意指定位置。这样会让插入位置后 面所有的元素进行移动,会影响处理速度。涉及大量元素时,尽量避免使用。类似发生这种 移动的函数还有:remove()、pop()、del(),它们在删除非尾部元素时也会发生操作位置后 面元素的移动。

 1 >>> a = [10,20,30]
 2       
 3 >>> id(a)
 4       
 5 1983366105288
 6 >>> a.insert(2,222)
 7       
 8 >>> a
 9       
10 [10, 20, 222, 30]
11 >>> id(a)
12       
13 1983366105288

五:乘法扩展

  使用乘法扩展列表,生成一个新列表,新列表元素是原列表元素的多次重复。

 1 >>> a = ['jack',100]
 2       
 3 >>> b = a*3
 4       
 5 >>> a
 6       
 7 ['jack', 100]
 8 >>> b
 9       
10 ['jack', 100, 'jack', 100, 'jack', 100]

  适用于乘法操作的,还有:字符串、元组。例如:

 1 >>> c = "abcd"
 2       
 3 >>> d = c*3
 4       
 5 >>> c
 6       
 7 'abcd'
 8 >>> d
 9       
10 'abcdabcdabcd'

 

posted on 2019-05-11 23:27  JACK#zhang  阅读(409)  评论(0编辑  收藏  举报