深浅copy
浅拷贝 只copy了一层 可哈希的变量改变则二者不同 不可哈希变量改变二者都改变
深拷贝 全部都copy了 不论什么值改变 原值都改变呢
变量赋值、浅拷贝、深拷贝
1,创建变量
1.1不可变对象
a = 'hello'
b = 'hello'
print id(a)
print id(b)
执行结果:
>>>
43461664
43461664
>>>
图
结果:a和b的id一样。因为创建b的时候解释器发现b的值是hello,hello是字符串,字符串是不可变对象。hello这个值在内存中已经有了,就不重新开辟内存空间了,所以就把b的引用指向了a的内存空间
1.2可变对象
a = ['hello']
b = ['hello']
print id(a)
print id(b)
内存图:
执行结果:
>>>
43140880
39227920
>>>
结论:a和b的id不一样。因为创建b的时候解释器发现b的值是[hello],[hello]是list,list是可变对象。所以直接开了一个新的内存空间
2,重新赋值
2.1不可变对象的赋值
a = 'hello'
print id(a)
a = 'world'
print id(a)
执行结果:
>>>
41495584
41495648
>>>
内存图:
2.2可变对象的赋值
a = ['hello']
print id(a)
a[0] = 'world'
print id(a)
执行结果:
>>>
42616592
42616592
>>>
内存图:
3,变量对变量的赋值
3.1不可变变量的赋值
a = 'hello'
b = 'hello'
a = b
print id(a)
print id(b)
执行结果:
>>>
41298976
41298976
>>>
3.2可变变量的赋值
a = ['hello']
print id(a)
b = ['hello']
#下面这一行会把b的引用赋值给a,然后把a的内存空间释放,a和b一起用b的内存空间
a = b
print id(a)
print id(b)
执行结果:
>>>
42157840
42157480
42157480
>>>
4,浅拷贝
浅拷贝会把子元素里面的可变元素弄成相同地址
list1 = ['hello',['world']]
list2 = list1[:]
print id(list1),list1
print id(list2),list2
print '-'*30
print id(list1[0]),u'id of list1-hello'
print id(list2[0]),u'id of list2-hello'
print '-'*30
print id(list1[1]),u'id of list1-world'
print id(list2[1]),u'id of list2-world'
执行结果:
40145424 ['hello', ['world']]
44057104 ['hello', ['world']]
------------------------------
43985952 id of list1-hello
43985952 id of list2-hello
------------------------------
44058384 id of list1-world
44058384 id of list2-world
结论:list1和list2地址不同,但是两个list里面的hello和world都相同,说明List是两份,但是里面的内容是1份
5,深拷贝
深拷贝会把子元素里面的可变元素弄成不同地址
5.1深拷贝
from copy import deepcopy
list1 = ['hello',['world']]
list2 = deepcopy(list1)
print id(list1),list1
print id(list2),list2
print '-'*30
print id(list1[0]),u'id of list1-hello'
print id(list2[0]),u'id of list2-hello'
print '-'*30
print id(list1[1]),u'id of list1-world'
print id(list2[1]),u'id of list2-world'
执行结果:
>>>
38900240 ['hello', ['world']]
42811920 ['hello', ['world']]
------------------------------
42740768 id of list1-hello
42740768 id of list2-hello
------------------------------
42813200 id of list1-world
42813760 id of list2-world
>>>
结论:深拷贝会把所有可变对象从新开辟内存空间,包含多层嵌套的可变对象,但是不可变对象还是只有1个地址
5.2深拷贝多加一层嵌套的例子
list1 = ['hello',['world',['abc']]]
list2 = deepcopy(list1)
print id(list1),list1
print id(list2),list2
print '-'*30
print id(list1[0]),u'id of list1-hello'
print id(list2[0]),u'id of list2-hello'
print '-'*30
print id(list1[1][1]),u'id of list1-abc'
print id(list2[1][1]),u'id of list2-abc'
执行结果:
>>>
41894416 ['hello', ['world', ['abc']]]
41908624 ['hello', ['world', ['abc']]]
------------------------------
41823264 id of list1-hello
41823264 id of list2-hello
------------------------------
41895696 id of list1-abc
41896536 id of list2-abc
>>>
深浅copy的更多相关文章
- python基础3(元祖、字典、深浅copy、集合、文件处理)
本次内容: 元祖 字典 浅copy和深copy 集合 文件处理 1.1元祖 元祖(tuple)与列表类似,不同之处在于元祖的元素不能修改,元祖使用小括号(),列表使用方括号[].元祖创建很简单,只需要 ...
- python学习笔记三 深浅copy,扩展数据类型(基础篇)
深浅copy以及赋值 对于字符串和数字而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. import copy n1 = #n1 = 'hahahaha' #赋值n2 = n1#浅co ...
- Python 第三篇(下):collections系列、集合(set)、单双队列、深浅copy、内置函数
一.collections系列: collections其实是python的标准库,也就是python的一个内置模块,因此使用之前导入一下collections模块即可,collections在py ...
- Python 基础之函数、深浅copy,set及练习
三元运算符通常在Python里被称为条件表达式,这些表达式基于真(true)/假(not)的条件判断,在Python 2.4以上才有了三元操作. 语法格式: X if C else Y 有了三元表达式 ...
- python基础(三)编码,深浅copy
编码,深浅copy encode,decode在python2中使用的一些迷糊,python3中更容易理解 要理解encode和decode,首先我们要明白编码,字符和二进制的相关概念,简单来说,计算 ...
- Python 集合 深浅copy
一,集合. 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...
- 基础数据类型的补充和深浅copy
一:关于str 的操作方法补充 1,s.isspace() 判断字符串是否只由空格组成,是,为True,否则,为False. s = ' ' #只能是以至少一个空格组成的字符串(全空格) prin ...
- python集合深浅copy
一,集合. 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...
- Python基础数据类型之集合以及其他和深浅copy
一.基础数据类型汇总补充 list 在循环一个列表时,最好不要删除列表中的元素,这样会使索引发生改变,从而报错(可以从后向前循环删除,这样不会改变未删元素的索引). 错误示范: lis = [,,, ...
- python之集合,深浅copy
一. 集合 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...
随机推荐
- thinkphp微信浏览器内拉起微信支付
vendor/wxpay/pay.php <?php /* +-----------------------------------+ | 微信支付类 | +------------------ ...
- Centos7/RHEL7 开启kdump
Kdump是一种基于kexec的Linux内核崩溃捕获机制,简单来说系统启动时会预留一块内存,当系统崩溃调用命令kexec(kdump kernel)在预留的内存中启动kdump内核, 该内核会将此时 ...
- vuejs2.0如何获取dom元素自定义属性值
1.设置定义属性值 :data-value=".." <ul class="header-ul"> <li class="flex ...
- python基础篇_004_装饰器函数
python装饰器函数 1.装饰器函数引导 功能:计算函数执行时长 import time """ 方式一: 函数首位添加时间,差值就是函数执行时间 缺点:每个函数都要加 ...
- 消息队列——ActiceMQ
1.下载apache-activemq-5.xx.x,\bin\win64目录下运行activemq.bat.之后可进入管理员界面http://localhost:8161/admin,账号密码均为a ...
- redis初步入门(1)
一.redis是一款高性能NOSQL系列的非关系型的数据库,其是用C语言开发的一个开源高性能键值对(key-value)数据库. 二.redis的应用场景 1.缓存(数据查询.短连接.新闻内容.商品内 ...
- 动态规划——Edit Distance
大意:给定两个字符串word1和word2,为了使word1变为word2,可以进行增加.删除.替换字符三种操作,请输出操作的最少次数 Example 1: Input: word1 = &quo ...
- echarts研究
1.echarts是什么? 关键字:data visualization,canvas,chart Echarts是基于轻量级的canvas类库,纯javaScript实现,MVC封装,数据驱动,一款 ...
- python3 request模块初使用
import requests class Interface_Request: def __init__(self,url,mobilephone,pwd): '''login参数初始化''' se ...
- OI/ACM 刷题网站 人气OJ简介
SPOJ简介 SPOJ是波兰最为出色的Online Judge之一,界面和谐,题目类型也非常丰富,适合有一定基础的选手练习,对高手而言也是个提高能力的良好平台. SPOJ题目分类:class ...