引用

Python是动态数据类型的语言,故在对变量进行赋值时是不用制定变量类型的。

或者说,你可以把变量赋值的过程,当作是贴一个标签,去引用该数据。

看下面的例子:

 In [54]: a=4

 In [55]: b=a

 In [56]: id(a)
Out[56]: 1652425264 In [57]: id(b)
Out[57]: 1652425264

可以看到,a与b志向了同一个地址。这便是引用


浅拷贝与深拷贝

先来看一个例子:

In [58]: import copy

In [59]: a=[1,2,3]

In [60]: b=copy.copy(a)

In [61]: c=copy.deepcopy(a)

上面便是调用了标准模块copy,b浅拷贝了a,c深拷贝了a。

接下来,再看看3个变量的地址:

In [62]: id(a)
Out[62]: 2069478787912 In [63]: id(b)
Out[63]: 2069479182856 In [64]: id(c)
Out[64]: 2069479074568

可以看到,相对与引用,浅拷贝与深拷贝后,变量指向的地址都变了。那么,深拷贝与

浅拷贝之间到底有什么区别呢?咱们接下去分析结果:

In [65]: id(a[0])
Out[65]: 1652425168 In [66]: id(b[0])
Out[66]: 1652425168 In [67]: id(c[0])
Out[67]: 1652425168

这下明白了吧!对于一个列表里的元素,深拷贝和浅拷贝还是指向了原来的内存地址。

看到这里是不是会误以为它们两个没区别呢?好吧,再看看下面:

In [92]: a={'people':['brad','Alex'],'I':'xiaole'}

In [93]: b=copy.copy(a)

In [94]: c=copy.deepcopy(a)

In [95]: id(a['people'])
Out[95]: 2069478460104 In [96]: id(b['people'])
Out[96]: 2069478460104 In [97]: id(c['people'])
Out[97]: 2069479089608

可以看到,对于‘people’,浅拷贝还是指向了原来的内存地址。而深拷贝,

就是实实在在指向不同的地址,说白了就是把数据放在了不同的地方。

再说白了,浅拷贝就是在在内存中只额外创建第一层数据。

好吧,至此以为全都弄明白了,那请解释下下面的结果:

In [98]: id(a['I'])
Out[98]: 2069482265320 In [99]: id(b['I'])
Out[99]: 2069482265320 In [100]: id(c['I'])
Out[100]: 2069482265320

为何对于元素‘I’,又指向了同一个地址。说好的元素指向不同了呢?

想弄明白,看下面的重点提醒,并去琢磨下吧。

重点提醒!!!

对于数字和字符串,赋值、浅拷贝和深拷贝的值都指向同一个内存地址。

In [68]: a=3

In [69]: b=copy.copy(a)

In [70]: c=copy.deepcopy(a)

In [71]: id(a)
Out[71]: 1652425232 In [72]: id(b)
Out[72]: 1652425232 In [73]: id(c)
Out[73]: 1652425232

In [74]: a='brad'

In [75]: b=copy.copy(a)

In [76]: c=copy.deepcopy(a)

In [77]: id(a)
Out[77]: 2069482263528 In [78]: id(b)
Out[78]: 2069482263528 In [79]: id(c)
Out[79]: 2069482263528

说明:本人所用的解释器为Ipython

Python 引用、浅拷贝、深拷贝解析的更多相关文章

  1. Python__学习路上的坑之--引用,浅拷贝,深拷贝

    copy : 相当于只是拷贝表面一层,如果里面还有深层次的引用,那么也是直接拷贝引用的地址,而且如果拷贝对象是不可变类型比如元组,那么也是直接拷贝引用. deepcopy: 无论是拷贝可变类型还是不可 ...

  2. 深度解析:python之浅拷贝与深拷贝

    深度解析python之浅拷贝与深拷贝 本文包括知识点: 1.copy与deepcopy 2.可变类型与不可变类型 1.copy与deepcopy 在日常python编码过程中,经常会遇见变量的赋值.这 ...

  3. **Python中的深拷贝和浅拷贝详解

    Python中的深拷贝和浅拷贝详解   这篇文章主要介绍了Python中的深拷贝和浅拷贝详解,本文讲解了变量-对象-引用.可变对象-不可变对象.拷贝等内容.   要说清楚Python中的深浅拷贝,需要 ...

  4. Python中浅拷贝和深拷贝的区别总结与理解

    单层浅拷贝 import copy a = 1 # 不可变数据类型 copy_a = copy.copy(a) print(id(a),id(copy_a)) # 内存地址相同 a = [1,2] # ...

  5. Python对象拷贝——深拷贝与浅拷贝

    对象赋值 浅拷贝 深拷贝 1. 对象赋值 对象的赋值实际上是对对象的引用.也就是说当把一个对象赋值给另一个对象时,只是拷贝了引用.如: >>> t1 = tuple('furzoom ...

  6. JS中有关对象的继承以及实例化、浅拷贝深拷贝的奥秘

    一.属性的归属问题 JS对象中定义的属性和方法如果不是挂在原型链上的方法和属性(直接通过如类似x的方式进行定义)都只是在该对象上,对原型链上的没有影响.对于所有实例共用的方法可直接定义在原型链上这样实 ...

  7. python引用和对象详解

    python引用和对象详解 @[马克飞象] python中变量名和对象是分离的 例子 1: a = 1 这是一个简单的赋值语句,整数 1 为一个对象,a 是一个引用,利用赋值语句,引用a指向了对象1. ...

  8. python中的深拷贝和潜拷贝

    >>> a = ['ace',['age',10]] >>> b = a[:] >>> c = list(a) >>> for ...

  9. python实现命令行解析的argparse的使用

    参考https://docs.python.org/3.6/library/argparse.html argparse模块使编写用户友好的命令行界面变得很容易.程序定义了它需要什么参数,argpar ...

随机推荐

  1. js架构设计模式——你对MVC、MVP、MVVM 三种组合模式分别有什么样的理解?

    你对MVC.MVP.MVVM 三种组合模式分别有什么样的理解? MVC(Model-View-Controller)MVP(Model-View-Presenter)MVVM(Model-View-V ...

  2. VMware虚拟机与宿主无法复制的解决办法

    由于工作需要,上网机器使用虚拟机,因此需要经常来回的拷贝文件,而vmware从6.5一直走来到10.0.1,总是有一个问题很让人苦恼---共享粘贴板总是会无故失效.经常实验,发现可以经过以下方法临时解 ...

  3. 用c3m自动生成的化学机理文件导入mfix里需要注意的一些问题

    1. 首先是类似这种写法: Species_g(1) = "CH4" Species_Alias_g(1) = "CH4" 可能会报错,写在一行可能就好了,如: ...

  4. PHP用户注册邮箱并验证激活帐号

    我们在很多网站注册会员时,注册完成后,系统会自动向用户的邮箱发送一封邮件,这封邮件的内容就是一个URL链接,用户需要点击打开这个链接才能激活之前在该网站注册的帐号.激活成功后才能正常使用会员功能. 查 ...

  5. Hibernate最简单教程

    其实Hibernate本身是个独立的框架,它不需要任何web server或application server的支持.然而,大多数的Hibernate入门介绍都加入了很多非Hibernate的东西, ...

  6. POJ2115(扩展欧几里得)

    C Looooops Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 23700   Accepted: 6550 Descr ...

  7. [CSS3] 学习笔记-CSS3选择器详解(一)

    1.属性选择器 在CSS3中,追加了3个属性选择器,分别为:[att*=val].[att^=val]和[att$=val],使得属性选择器有了通配符的概念. <!doctype html> ...

  8. MongoDB基础之八 备份与恢复

    Mongodb导出与导入 1: 导入/导出可以操作的是本地的mongodb服务器,也可以是远程的.所以,都有如下通用选项:-h host 主机--port port 端口-u username 用户名 ...

  9. java_db常见错误总结

    1.java.sql.SQLSyntaxErrorException: ORA-00911: 无效字符 在拼写seq时是否存在存在特殊字符,如:常见语句后面添加了;2.ORA-01722:无效数字解决 ...

  10. linq左连接查询加上into后怎么查询右表是否为空

    //判断右表是否为空并为映射表进行赋值标志var query=from q in product join m in favProduct on q.Name equals m.Name into t ...