ls = [3, 4, 5]
ls = ls + [7,4]
print(ls) #该操作速度较慢,在涉及大量元素添加时不建议使用该方法。
结果: [3, 4, 5, 7, 4]
** 注意: **严格意义上来讲,这并不是真的为列表添加元素,而是 创建了一个新列表 ,并将原列表中的元素和新元素依次复制到新列表的内存空间。由于涉及大量元素的复制,该操作速度较慢,在涉及大量元素添加时不建议使用该方法。
a1 = [1, 2, 3]
b1 = [1, 2, 3]
print(id(a1) == id(b1)) #a、b的ID不一样
print(id(a1[0]) == id(b1[0]))
结果: False
True
注意:
Python采用的是基于值的自动内存管理方式,当为对象修改值时,并不是真的直接修改变量的值,而是使变量指向新的值,这对于Python所有类型的变量都是一样的。
原地操作
如果是通过下标来修改序列中元素的值或通过可变序列对象自身提供的方法来增加和删除元素时,序列对象在内存中的起始地址是不变的,仅仅是被改变值的元素地址发生变化,也就是所谓的“原地操作”。
a = [1, 2, 3, 4]
print(id(a)) # 直接修改列表的值,会产生一个新的列表
a.append(5)
print(id(a)) # 用append()方法属于原地修改
a[1] = 'h'
print(a)
print(id(a)) # 用下标修改列表元素,属于原地修改
在上面 a 的基础之上
用 extend( ) 方法,insert( )方法
# extend( ) 方法:在列表尾部添加另外一个可迭代对象
str1 = 'hello' # 在尾部扩展一个字符串
a.extend(str1)
print(a)
# insert()方法:将元素插入列表的指定位置。但会影响速度
a.insert(2, '*') #在下标为2的位置插入元素'*'
print(a)
尽量从列表尾部进行元素的增加与删除操作。