python高级-深浅拷贝(16)
一、浅拷贝
浅拷贝是对一个对象的顶层拷贝,通俗地讲就是:拷贝了引用,并没有拷贝内容。
a = [1,2,3]
print(id(a))
b=a
print(b)
print(id(b))
a.append(4)
print(a)
print(b)
运行结果为:
1965053928072
[1, 2, 3]
1965053928072
[1, 2, 3, 4]
[1, 2, 3, 4]
二、深拷贝
深拷贝是对于一个对象所有层次的拷贝,重新开辟内存地址。
import copy
a = [1,2,3]
print(id(a))
#使用copy模块
b = copy.deepcopy(a)
#打印b的内存地址
print(id(b))
a.append(4)
print(a)
print(b)
运行结果为:
2035157969672
2035158105992
[1, 2, 3, 4]
[1, 2, 3]
三、深浅拷贝对比
import copy
a = [1,2,3]
b = [4,5,6]
c = [a,b] d = c #直接赋值,浅拷贝
print("c的内存地址为:%s"%id(c))
print("d的内存地址为:%s"%id(d)) #使用copy模块
#深拷贝,重新开辟内存,并内容独立
e = copy.deepcopy(c)
#深拷贝,重新开辟内存,但是新内容里面仍保存原来的引用
f = copy.copy(c)
#打印e,f的地址
print("e的内存地址为:%s"%id(e))
print("f的内存地址为:%s"%id(f)) #改变a的值
a.append(44) #打印a,b,c,d,e,f
print("a = %s"%a)
print("b = %s"%b)
print("c = %s"%c)
print("d = %s"%d)
print("e = %s"%e)
print("f = %s"%f)
运行结果为:
c的内存地址为:2514746494856
d的内存地址为:2514746494856
e的内存地址为:2514746494920
f的内存地址为:2514746494664
a = [1, 2, 3, 44]
b = [4, 5, 6]
c = [[1, 2, 3, 44], [4, 5, 6]]
d = [[1, 2, 3, 44], [4, 5, 6]]
e = [[1, 2, 3], [4, 5, 6]]
f = [[1, 2, 3, 44], [4, 5, 6]]
说明:
- c和d的内存地址一样,说明是浅拷贝,两个引用指向的是同一块内存
- c,e,f内存地址不一样,说明e和f都是深拷贝,都重新开辟的内存地址
- 在a追加了元素44之后,打印的e中并有追加44,说明深拷贝,内容独立
- 在a追加了元素44之后,打印的f中也追加44,说明f也重新开辟了内存,但是新内容里面保存的是原来的引用
四、copy对可变和不可变对象的不同
1、可变类型使用copy
import copy
a = [1,2,3]
b = copy.copy(a)
print(id(a))
print(id(b)) a.append(4)
print(a)
print(b)
运行结果为:
1626677717832
1626677715784
[1, 2, 3, 4]
[1, 2, 3]
2、不可变类型使用copy
import copy
a = (1,2,3)
b = copy.copy(a)
print(id(a))
print(id(b))
运行结果为:
2043444280704
2043444280704
总结:
- 简单的赋值是浅拷贝
- copy模块里面的copy()函数可以做一层深拷贝,虽然重新开辟了新的内存,但新内存里面仍然存放得是原来的引用,
- copy模块中的deepcopy()函数是深拷贝,重新开辟了了内存,而且内存中保存了新的值
python高级-深浅拷贝(16)的更多相关文章
- Python原理 -- 深浅拷贝
python原理 -- 深浅拷贝 从数据类型说开去 str, num : 一次性创建, 不能被修改, 修改即是再创建. list,tuple,dict,set : 链表,当前元素记录, 下一个元素的位 ...
- Python的深浅拷贝
Python的深浅拷贝 深浅拷贝 1. 赋值,对于list, set, dict来说, 直接赋值. 其实是把内存地址交给变量并不是复制一份内容 list1 = [']] list2 = list1 p ...
- 24、简述Python的深浅拷贝以及应用场景
深浅拷贝的原理 深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:copy.deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝 ...
- Python入门-深浅拷贝
首先我们在这里先补充一下基础数据类型的一些知识: 一.循环删除 1.前面我们学了列表,字典和集合的一些操作方法:增删改查,现在我们来看一下这个问题: 有这样一个列表: lst = ['周杰伦','周润 ...
- day2学python 数据类型+深浅拷贝+循环
数据类型+深浅拷贝+循环 别的语言的数组 python不用定义 直接使用 color=['红','橙','黄','绿','青','蓝','紫'] print(color[1:3]) //打印[1,3) ...
- 简述Python的深浅拷贝以及应用场景
深浅拷贝的原理 深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:copy.deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝 ...
- python 赋值 深浅拷贝
深浅拷贝 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 impor ...
- Python随笔---深浅拷贝
Python中为了避免某些方法的副作用(拷贝后有时更改原有数据),故存在有深浅拷贝的存在 浅拷贝导入copy方法集,使用copy_copy的方法进行 深拷贝一样导入copy方法集,使用copy_dee ...
- python 的深浅拷贝问题
深浅拷贝概念 基本类型和引用类型数据拷贝的问题.因为基本类型的数据大小是固定的,所以他保存在栈内存中:而引用类型的数据大小不固定,因而保存在堆内存中,单引用类型在栈内存中只保存一个指向堆内存的指针. ...
随机推荐
- Java多线程编程核心技术(一)
先提一下进程,可以理解为操作系统管理的基本单元. 而线程呢,在进程中独立运行的子任务.举个栗子:QQ.exe运行时有很多子任务在同时运行,比如好友视频线程.下载视频线程.传输数据线程等等. 多线程的优 ...
- java开发过程中,报错Dangling meta character '*' near index 0,解决办法
1.split方法转化字符串为数组: String[] strPicArr = map.get("hw_pic").toString().split("*"); ...
- huffman树实现的压缩算法,java
1.树的构建 package huffman; public abstract class BinaryTreeBasis { protected TreeNode root; public Bina ...
- python之路(七)-递归算法
递归 特点 递归算法是一种直接或者间接地调用自身算法的过程.在计算机编写程序中,递归算法对解决一大类问题是十分有效的,它往往使算法的描述简洁而且易于理解. 递归算法解决问题的特点: (1) 递归就是在 ...
- centos 安装部署zabbix
Zabbix_server初始安装部署 各模块要安装的模块 Server:server+nginx+mysql+php Agentd:agentd Proxy:proxy+mysql 1.准备环境: ...
- POJ - 3278 Catch That Cow bfs 线性
#include<stdio.h> #include<string.h> #include<algorithm> #include<queue> usi ...
- 学习Python第四天
关于剩下的数据类型:字符串 字符串是有序的,不可变的(不可变的意思是指将变量a重新赋值后不会覆盖原来的值,而是在内存中开辟了一块新的内存地址,存储变量的值) 字符串的各种方法: 1,将字符串中的大写变 ...
- tarjan算法总结
部分内容引自https://www.cnblogs.com/stxy-ferryman/p/7779347.html Tarjan算法不是一个算法而是一类算法 1.求取强连通分量 强连通分量————有 ...
- day_3各种数据类型与各种运算符
首先我们复习一下昨天的内容 1:语言的分类: --有三种 机器语言,汇编语言,高级语言 运行的效率是机器语言最高 开发效率 是高级语言最高 2:计算机由五大部分组成:控制器+运算器+存储器+inpu ...
- Linux下MySQL数据库的安装
记录详细过程以备使用 1.创建群组及用户 obd:~ # groupadd mysql obd:~ # useradd -g mysql mysql 2.创建相关目录 obd:~ # mkdir -p ...