博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python学习教程:Python列表赋值,复制,深拷贝及5种浅拷贝详解
阅读量:2383 次
发布时间:2019-05-10

本文共 1265 字,大约阅读时间需要 4 分钟。

Python学习教程:Python列表赋值,复制,深拷贝及5种浅拷贝详解

概述

在列表复制这个问题,看似简单的复制却有着许多的学问,尤其是对新手来说,理所当然的事情却并不如意,比如列表的赋值、复制、浅拷贝、深拷贝等绕口的名词到底有什么区别和作用呢?
在这里插入图片描述
列表赋值

# 定义一个新列表l1 = [1, 2, 3, 4, 5]# 对l2赋值l2 = l1print(l1)l2[0] = 100print(l1)

示例结果:

[1, 2, 3, 4, 5][100, 2, 3, 4, 5]

可以看到,更改赋值后的L2后L1同样也会被更改,看似简单的“复制”,在Python中,列表属于可变对象,而对可变对象的复制其实就是将列表的内存空间类似C中的指针再次指向新的变量名,而不是诸如字符串这种不可变对象在复制时会创建新的内存空间进行赋值。即此时L1和L2指向的是同一片内存空间,那么怎么实现真正复制呢?

浅拷贝

当列表中的元素为不可变对象时,我们可以用以下方法对列表进行赋值:

import copy# 定义一个新列表L0 = [1, 2, 3, 4, 5]print(L0)print('-'*40)

利用切片

L1 = L0[:]L1[0] = 100print(L0)

利用模块copy

import copyL2 = copy.copy(L0)L2[0] = 100print(L0)

利用list()

L3 = list(L0)L3[0] = 100print(L0)

利用列表方法extend

L4 = []L4.extend(L0)L4[0] = 100print(L0)

利用列表推导

L5 = [i for i in L0]L5[0] = 100print(L0)

可以看到最终的打印结果都是[1, 2, 3, 4, 5],我们成功进行了列表的复制,但是为了条件需要是列表中元素为不可变对象呢? 因为如果列表中的元素为可变对象,在复制时有会发生对象的引用,而不是新建内存空间进行引用,比如:

L0 = [1, 2, [3], 4, 5]print(L0)L2 = L0[:]L2[2][0] = 100print(L0)

示例结果:

[1, 2, [3], 4, 5][1, 2, [100], 4, 5]

可以看到,当列表L0中含有可变对象时,对复制后的L1进行改变其中可变对象元素L2[2]时,L0中的可变对象L0[2]也发生了改变,那么怎么实现真正的完全的拷贝呢?

深拷贝

利用copy模块中的deepcopy进行深拷贝:

import copyL0 = [1, 2, [3], 4, 5]print(L0)L2 = copy.deepcopy(L0)L2[2][0] = 100print(L2)print(L0)

示例结果:

[1, 2, [100], 4, 5][1, 2, [3], 4, 5]

更多的Python学习教程会继续为大家更新!初学Python的小伙伴们也要跟着系统的Python学习路线走哦!

转载地址:http://ttkab.baihongyu.com/

你可能感兴趣的文章
使用regasm注册.net com组件出现不是有效的.net程序集的解决办法
查看>>
VS自定义开发向导中的vsdir文件的简单说明
查看>>
svn回到某个历史版本的做法
查看>>
pugixml读取unicode编码的xml文件的做法
查看>>
VS 2005环境下使用boost ::bind的一个注意事项
查看>>
图形图像显示研究(一)
查看>>
GRETA库在VS 2005环境下的编译经验
查看>>
忆父亲
查看>>
png库结合zlib库使用出现的一个链接问题的解决
查看>>
STL数组和com数组相互转换的做法
查看>>
开发平台软件中关于第三方库管理的一些思考
查看>>
svn创建分支的做法
查看>>
“当前不会命中断点。源代码与原始版本不同”的问题的有效解决办法
查看>>
对面向对象和面向过程的一些新理解
查看>>
软件开发中的资源管理
查看>>
gdal集成kml库的做法
查看>>
对类前置声明和包含头文件的一点理解
查看>>
DLL封装框架视图经验总结二
查看>>
重新找回心灵的感动
查看>>
在软件开发中用户应该扮演怎样的角色
查看>>