在众多的学习经验中,我们都会推崇一种追根溯源的精神,就好比是写一个自动化脚本,我们需要的做的不仅仅是将这个脚本写出来实现应有的功能,而是应该了解这个功能应该是怎么实现的,它做了些什么?就像最近客户和我们交流的内容一样,“我们不应该只是浮于表面,知道容灾切换页面上手工操作的部分,不要局限于工具操作,需要的是去掌握不同产品在切换时候的状态,它们到底是需要具备什么样的状态等等”。不约而同的思想,在python的学习中同样适用。
那么,今天我就从另外的一个视角来和大家一起聊聊python中的列表。
1、列表是什么?一系列变量组成的可变序列
这里我们划一下重点。
变量组成列表是包含了很多个变量的,而之所以称之为变量,肯定是因为它可以修改。所以列表是可以被修改的。列表的修改就包含了它的很多基本操作,比如说append,remove,insert,del等。
可变基于上一点,我们可知,列表是零个或多个变量组成的,这里就很容易知道,一个列表可以包含很多各元素,而当一个创建好的列表,我们也是可以修改它的长度,也就是对它里面的某一个或者某一些元素做操作,也就是所谓的增删改相关的操作。
序列顾名思义,列表是有顺序而言,也就是说我们可以对一个列表做排序的操作。对于python而言,列表的排序就很容易,因为它就自定义了排序方法sort,就可以很轻松实现列表的这一特点。
2、从内存的角度认识列表我们刚刚已经知道了什么是列表,那么列表究竟是什么样的呢?大家肯定都知道不就是类似"[]"的一种形式的东西,我这里想说的当然不只是这个方面了。
比如list1=[1,2,,4],list2=[a,b,c,d]等等。
案例1:案例1分析:list1=[2,]:
list1是变量,代表内存中的一块地址0x,在内存中存放的是列表的地址0x。
0x也是一块地址,存放的是两个元素的地址0x和0x,该地址由分别指向自己的元素。
list2=list1
表示的是把list1的内存地址也同时给到了List2,换句话说list2指向的也是list1所拥有的的内存地址0x.
list1[0]=:
当修改list1的0元素为时,在内存中假设地址为0x5,相当于把0x的内存地址指向另一个新的地址0x5,原来指向的0x就不存在了。
所以list2在此时所指向的也是0x,list2=[,2]
printlist2[0]结果就是
以上所展示的就是理解意义上的内存图。
结合上面的案例我们再来谈一下列表。
如list1,表示的就是一个列表,本质一个变量地址,存放的是列表元素所在的地址,因为想要在内存中找到我们所创建的list1,不妨就把两个元素的地址用一个新的地址所代替了,其实找到了list1中任意一个元素的位置,也就代表访问到了list1。而list1这个变量所存放的内存地址表示的是列表,列表又是由变量组成的可变序列,所以,我们可以对列表做修改,其本质就是改变了内存的地址指向,就像修改list1[0]一样,在内存中发生的变化就是list1[0]元素的位置发生了变化。
分析:开始list1和list2的0元素都是执行ID为的位置,重新赋值后,又同时变成了。和我们上面内存图中的结论一模一样。
本节就是简单的从内存的角度分析了下,列表在内存中的形态。有利于帮助我们更好的使用列表,在更多复杂的列表场景中,我们就会很容易知道列表是发生了怎样的变化,希望能够对大家有所帮助。