浅拷贝,记住一点,浅拷贝无论多复杂,只copy第一层,看图说话。
一、定义源列表list_s,列表list_c,并进行拷贝操做,查看两列表的值相等,以下图所示。数据结构
二、如今源列表list_s数据更改,增长数值list_s.append(3),list_s数值改变,而列表list_c的值不变,以下图所示。
三、如今list_c数据更改,增长数值list_c.append(4),list_c数值改变,而源列表list_s的数值保持不变,以下图所示。
由以上三步操做能够看出,源list_s里面嵌套了[3,4]列表,对源list_s进行追加3,发现list_s数值改变,而list_c数值没有改变,而对list_c追加4,发现list_s数值未改变,而list_c数值改变了,那么对源list_s里面的[3,4]进行改变,看list_s和list_c数值会发生怎样的变化,继续往下看。
四、修改源list_s里面的[3,4]值,增长5,变成[3,4,5],发现源list_s改变,list_c数值也发生改变,并且,二者更改的地方是同样的,都变成了[3,4,5],以下图所示。
五、那么修改list_c里面的[3,4,5]值,增长6,变成[3,4,5,6],发现list_c改变,源list_s数值也发生改变,并且,二者更改的地方是同样的[3,4,5,6],以下图所示。
由以上两步操做能够看出,无论是源list_s,仍是list_c改变列表中嵌套的列表[3,4]的值时,源list_s和list_c都会发生改变,并且变化同样。
从内存地址来看,以下图所示。app
绿色的为追加的内容,能够看出,进行浅拷贝以后,列表中嵌套的列表[3,4]指向的内容以及地址,并未发生改变,因此,不论[3,4]发生什么样的改变,llist_s和list_c都会发生一样的改变,而第一层的列表,list_s和list_c都是相互独立的,二者发生改变不会影响对方。ide
搞明白浅拷贝以后,深拷贝就很好理解了,深拷贝就是在内存中从新开辟一块空间,无论数据结构有多复杂,只要数据发生改变,就从新开辟一块内存空间把内容复制下来,直到最后一层,通俗点讲就是,深拷贝就是从新定义一个变量,于以前的没有半毛钱关系,因此更改里面的内容,原来的并不会发生改变。举例说明,以下图所示。
定义list_s=[1,2,[3,4]],而list_c进行深拷贝,初始值,二者同样,而后对list_s追加3,对list_c中的列中中的列表[3,4]追加5,发现,list_s为[1,2,[3,4],3], list_c为[1,2,[3,4,5]]彼此的变化并无影响对方。3d