Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果。

下面本文就通过简单的例子介绍一下这些概念之间的差别。

一、对象赋值

  又叫变量对对象的引用

li=["Will", 28, ["Python", "C#", "JavaScript"]]
new_li=li print(id(li)) #
print([id(ele) for ele in li]) #[1369692104328, 1511377424, 1369692110600] print(id(new_li)) #
print([id(ele) for ele in new_li]) #[1369692104328, 1511377424, 1369692110600]

  可以看出li赋值给了new_li,同时,new_li是引用了li的内存地址

  当对数据做修改的操作时:

  1、经本人多次试验考证,发现对象赋值,不论多么复杂的数据结构,你对任意数据做了修改之后,都会影响到另一个

  2、而且,若数据为可变数据类型,修改数据后,内存地址都不会变

  3、若为不可变数据类型,修改数据后,会替换掉旧的对象,即内存地址会发生改变 

li=["Will", 28, ["Python", "C#", "JavaScript"]]
new_li=li print([id(ele) for ele in li]) #[1925751432840, 1511377424, 1925751446472] li[0] = "Wilber"
li[1] = 22
li[2].append("CSS") print ([id(ele) for ele in li]) #[1925751447768, 1511377232, 1925751446472]

二、浅拷贝

import copy
li=["Will", 28, ["Python", "C#", "JavaScript",[
{'mm':1},
{'mm':2},
{1,2,3}
]]]
new_li=copy.copy(li) print([id(ele) for ele in li]) #[1474180867888, 1511377424, 1474180874120]
print([id(ele) for ele in new_li]) #[1474180867888, 1511377424, 1474180874120] new_li[0] = "Wilber"
new_li[1] = 22
new_li[2].append("CSS")
new_li[2][3][0]='xx'
new_li.append('sss') print (li) #['Will', 28, ['Python', 'C#', 'JavaScript', ['xx', {'mm': 2}, {1, 2, 3}], 'CSS']]
print ([id(ele) for ele in li]) #[1474180867888, 1511377424, 1474180874120] print (new_li) #['Wilber', 22, ['Python', 'C#', 'JavaScript', ['xx', {'mm': 2}, {1, 2, 3}], 'CSS'], 'sss']
print ([id(ele) for ele in new_li]) #[1474180883040, 1511377232, 1474180874120]

  可以看出浅拷贝只拷贝了最外面一层的数据,当对最外面一层做改动时,不会影响到另一个,但是对套在里面的数据做改动就会影响到另外一个。

  注:切片的效果和浅拷贝一样

三、深拷贝

import copy
li=["Will", 28, ["Python", "C#", "JavaScript",[
{'mm':1},
{'mm':2},
{1,2,3}
]]]
new_li=copy.deepcopy(li) print([id(ele) for ele in li]) #[1609895241352, 1511377424, 1609895247752]
print([id(ele) for ele in new_li]) #1609895241352, 1511377424, 1609895247816] new_li[0] = "Wilber"
new_li[1] = 22
new_li[2].append("CSS")
new_li[2][3][0]='xx'
new_li.append('sss') print (li) #['Will', 22, ['Python', 'C#', 'JavaScript', [{'mm': 1}, {'mm': 2}, {1, 2, 3}]]]
print ([id(ele) for ele in li]) #[1609895241352, 1511377232, 1609895247752] print (new_li) #['Wilber', 28, ['Python', 'C#', 'JavaScript', ['xx', {'mm': 2}, {1, 2, 3}], 'CSS'], 'sss']
print ([id(ele) for ele in new_li]) #[1609895256448, 1511377424, 1609895247816, 1609895256728]

  会发现深拷贝对每一层数据都做了拷贝,即对任一数据做了改动,都不会影响到另一个。

四、总结

  1、对象赋值是对对象内存地址的引用,它代表原始对象,所以不论对哪一个做了改动,都会影响到另外一个

  2、copy.copy()浅拷贝,只对第一层元素进行拷贝

  3、若想复制一个容器对象及里面的所有元素(包含元素的子元素),可以使用copy.deepcopy()进行深拷贝

  4、对于非容器类型(如数字、字符串、等不可变类型的对象)没有被拷贝一说

 

python深浅拷贝问题的更多相关文章

  1. Python开发【第二章】:Python深浅拷贝剖析

    Python深浅拷贝剖析 Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果. 下面本文就通过简单的例子介绍一下这些概念之间的差别. 一.对象赋值 ...

  2. 小学生都能学会的python(深浅拷贝)

    小学生都能学会的python(深浅拷贝) join() 把列表中的每一项用字符串拼接起来 # lst = ["汪峰", "吴君如", "李嘉欣&quo ...

  3. 【0806 | Day 9】三张图带你了解数据类型分类和Python深浅拷贝

    一.数据类型分类 二.Python深浅拷贝

  4. 底层剖析Python深浅拷贝

    底层剖析Python深浅拷贝 拷贝的用途 拷贝就是copy,目的在于复制出一份一模一样的数据.使用相同的算法对于产生的数据有多种截然不同的用途时就可以使用copy技术,将copy出的各种副本去做各种不 ...

  5. 关于python深浅拷贝的个人浅见

    起初,关于python的深浅拷贝,总是习惯去用传值传址的方式去考虑,发现总是get不到规律,容易记混. python有着高度自治的内存管理,而不可变对象的内存分配,则是能省则省,就是说,无论用什么拷贝 ...

  6. python深浅拷贝与赋值

    初学编程的小伙伴都会对于深浅拷贝的用法有些疑问,今天我们就结合python变量存储的特性从内存的角度来谈一谈赋值和深浅拷贝~~~ 预备知识一——python的变量及其存储 在详细的了解python中赋 ...

  7. python 深浅拷贝 进阶

    主要理解新与旧究竟在哪里 这样也就理解了 深浅拷贝 先说说赋值,事实上python中的赋值事实上是赋值了一个引用.比如: foo1=1.0 foo2=foo1 用操作符is推断时.你能够发现结果是tr ...

  8. python深浅拷贝&垃圾回收&上下文管理(with语句)

    深浅拷贝 在Python中使用copy模块用于对象的拷贝操作. 该模块提供了两个主要的方法:浅拷贝 copy.copy() 深拷贝 copy.deepcopy() 1.浅拷贝(copy) 浅拷贝: 不 ...

  9. 关于Python深浅拷贝

    拷贝: 说明:原则上就是把数据分离出来,复制其数据,并以后修改互不影响. 何来深浅拷贝的说法? 深浅拷贝的“深”和“浅”可以理解为从变量到硬盘上的物理存储介质之间的层次的多少. 下面用一个示例来解释浅 ...

  10. python 深浅拷贝 for循环删除

    ###########################总结########################### 1. 基础数据类型补充 大多数的基本数据类型的知识.已经学完了 a='aaaa' ls ...

随机推荐

  1. HTML head元素

    head标签中可以包含的标签元素有: <title>:定义html页面的标题 <meta>: <meta> 标签提供了元数据.元数据也不显示在页面上,但会被浏览器解 ...

  2. bzoj3625

    fft 分治虽然是万能的,但是太慢了 分治是nlog^2n的,太慢了,于是我们用求逆和开根 设f(x)表示答案为x的方案数 c表示物品的生成函数 那么f=f*f*c+1 f*f表示左右儿子的方案数 c ...

  3. 深度学习之Batch归一化

    前言            以下内容是个人学习之后的感悟,转载请注明出处~ Batch归一化 在神经网络中,我们常常会遇到梯度消失的情况,比如下图中的sigmod激活函数,当离零点很远时,梯度基本为0 ...

  4. 2014年将会受欢迎的IT技能--你有多少哪?

    据国外媒体报道,据Global Knowledge等十几家研究机构发布的2014年IT技能和薪金调查报告显示,2014年最受欢迎的十大IT技能如下: 1.编程与应用开发 据美国劳工统计局称,开发者和程 ...

  5. Apple Tree

    题意: 给一有根树,每个叶子上有一些苹果,现在要求你拿掉一些苹果,使得每一个点的 儿子的子树内的苹果数相同. 解法: 首先可以发现$cnt$个叶子节点之间的关系可以用$cnt-1$个独立方程表示出来. ...

  6. 2-1Java简介

    java程序执行流程 java平台:

  7. sqlserver——视图

    数据库中的视图是一个虚拟表.同真实的表一样,视图包含一系列带有名称的列和行数据,行和列数据用来自由定义视图和查询所引用的表,并且在引用视图时动态产生.本篇将通过一些实例来介绍视图的概念,视图的作用,创 ...

  8. 死磕 java同步系列之volatile解析

    问题 (1)volatile是如何保证可见性的? (2)volatile是如何禁止重排序的? (3)volatile的实现原理? (4)volatile的缺陷? 简介 volatile可以说是Java ...

  9. 51nod1416(dfs)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1416 题意:中文题诶- 思路:dfs 搜索同一颜色的点.. 只 ...

  10. 洛谷P1291 百事世界杯之旅

    P1291 百事世界杯之旅 题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听, ...