版本使用Pyhon3.8.5
操作系统为Windows
列表是动态的,元组是静态的,这样的区别会影响两者的储存方式。
知识前提: 1 int = 8字节 1字节 = 8位
列表是动态的,需要存储指针,所以创建一个列表要比元组分配的空间多
用ipython直观实现,创建一个空列表占40个字节,像列表中添加一个元素,python分配32个字节给列表,这样往后添加三个元素只需要添加到分配的剩余字节里,当需要添加另外的元素时,python又会添加32个字节,可以存放另外4个元素。
元组与列表不一样,它不能被改变,而且存储空间占用比列表不一样。
python的垃圾回收机制:python对于静态数据会做一些资源缓存,如果一些变量不被使用,python就会回收他们的占用的内存,以供其它变量或应用使用。
对于元组来说,如果它不被使用并且占用空间不大时,Python 会暂时缓存这部分内存。这样,下次我们再创建同样大小的元组时,Python 就可以不用再向操作系统发出请求,去寻找内存,而是可以直接分配之前缓存的内存空间,这样就能大大加快程序的运行速度。
元组与列表初始化所需时间不一样
显而易见,元组更快。
列表与元组索引时间差不多