元组和列表最大的区别是列表中元素可以随意修改,就好比用铅笔在纸上写的字,写错了擦了重写;而元组中的元素无法修改,除非给元组重新赋值,就好比圆珠笔写的字擦不掉除非换纸。可以理解为元组是一个只读版本的list列表
list_1 = []
print(list_1.__sizeof__())
tuple_1 = ()
print(tuple_1.__sizeof__())
结果
40
24
相比之下,虽然两者都是空的,但是元组却比列表少战16个字节,这是为什么?
事实上由于列表是动态的,它需要存储指针来指向对应的元素(占用8个字节)。另外,由于列表中元素可变,所以需要额外存储已经分配的大小(占8个字节)。但是对于元组,清空就不同了,元组长度大小固定,且存储元素不可变,所以存储空间也是固定的。
那么就会有人问,既然列表已经这么强大还要元组这种类型干啥?
- 通过以上对比列表和元组存储方式有差异,即元组比列表更加轻量级,所以从总体来说,元组的性能速度要优于列表。
- python在后台会对静态数据做一些资源缓存。通常来说,因为垃圾回收机制的存在如果一些变量不被使用了,python就会挥手它们所占的内存反还给操作系统,以便其他变量或其他应用使用
- 但是对于一些静态变量(比如元组),如果它不被使用并且所占空间不大时,python会暂时缓存这部分内存,这样的话当下次再创建同样大小的元组时,python就可以不用再向操作系统发出请求去寻找内存,而是可以直接分配之前缓存的内存空间,这样就能大大加快程序的运行速度
- 当然,如果你想要增加或者删除改变元素,那么列表显然更有。因为对于元组来说必须得通过新建一个元组来完成
总的来说,元组确实没有列表那么多功能,但是元组依旧是很重要的序列类型之一,元组的不可替代性体现在以下这些场景中:
- 元组作为很多内置函数和序列类型方法返回值的存在,也就是说,在使用某些函数或者方法时,它的返回值会是元组类型,因为你必须对元组进行处理
- 元组比列表访问和处理速度更快,因此当需要对指定元素进行访问时,且不涉及修改源的操作建议使用元组