主要理解新与旧究竟在哪里 这样也就理解了 深浅拷贝

先说说赋值,事实上python中的赋值事实上是赋值了一个引用。比如:

foo1=1.0

foo2=foo1

用操作符is推断时。你能够发现结果是true。是由于python是先创建了一个对象1.0,然后这个对象的引用又被赋值给了foo1和foo2,可是假设是这样:

foo1=1.0

foo2=1.0

这时你会发现。这事实上是创建了两个不同的对象。用内建函数id()能够发现,二者的身份不同。

事实上python另一个特例,比如:

a=1

b=1

你会发现id(a)=id(b),原因是python觉得这些小整型是会经经常使用到的,所以python会缓存一部分小整型。

其次再说说浅拷贝和深拷贝。

序列类型的能够通过三种方式实现浅拷贝,浅拷贝也是默认的拷贝类型:(1)全然切片操作;(2)利用工厂函数。比方list()等;(3)使用copy模块中的copy()函数。然而对于非容器类型没有拷贝这这一说。在《python核心编程》一书中说道,“对一个对象进行浅拷贝事实上是新创建了一个类型跟原对象一样。其内容是原来对象元素的引用,换句话说。这个拷贝的对象本身是新的。可是它的内容不是”读完这句话我的理解是浅拷贝事实上是赋值,但后来发现不然,由于赋值的结果是他们的身份同样。可是浅拷贝的身份却不同,以下我结合书上的样例以及我自己的想法来说明这句话是什么意思。

fanwei@ubuntu:~$ python

Python 2.6.5 (r265:79063, Apr 16 2010, 13:09:56)

[GCC 4.4.3] on linux2

Type "help", "copyright", "credits" or "license" for more information.

>>> person=['name',['saveing',100]]

>>> wife=person[:]

>>> hubb=list(person)

>>> id(person)

3078619916L

>>> id(wife)

3078621548L

>>> id(hubb)

3078621996L

从代码的结果能够看出hubb和wife尽管是person浅拷贝的结果可是他们身份却不同。再看看他们的内容
>>>[id(x) for x in hubby]
[3078622112L,3078534412L]
>>>[id(x) for x in wife]
[3078622112L,3078534412L]
二者内容的身份却是一样的。

从这一点能够看出所谓的“拷贝对象本身是新的“就是之前代码验证的person、hubb和wife的身份不同。”内容是旧的“就是我们刚刚验证的,所以说事实上内容的浅拷贝能够看做是”赋值“。你会发现,假设我们将hubb中的’100‘改成’50‘,wife中的’100‘也变成了’50‘这就说明事实上内容的浅拷贝就是”赋值“即两个引用指向同一个对象,改变后二者的身份还是同样。

此外,因为hubb[0]、wife[0]是字符串,所以他们没有拷贝一说。是创建了一个新的类型。所以当把二者中的’name‘改名后,他们的身份就不同了。对于深拷贝无论是对象和内容身份都是不同的。这点就不再多说了。

如今。应该明确所谓的”对象本身是新的。内容是旧的“这句话的真正含义了吧。

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深浅拷贝&垃圾回收&上下文管理(with语句)

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

  8. 关于Python深浅拷贝

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

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

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

随机推荐

  1. Mysql学习总结(7)——MySql索引原理与使用大全

    一.索引介绍 索引是对数据库表中一列或多列的值进行排序的一种结构.在关系数据库中,索引是一种与表有关的数据库结构,它可以使对应于表的SQL语句执行得更快.索引的作用相当于图书的目录,可以根据目录中的页 ...

  2. qt hex to dec

    QString s = "32FE12AD";        quint8 u8vlaue = 0;        sscanf(s.toStdString().c_str(),  ...

  3. swift 编译提前定义 --不知道怎么定义,可是能够#if

    var v:Int; #if _COND//不知道怎么定义.可是能够#if v = ; #else ; #endif println(v);//2

  4. [Servlet]研究ServletContext对象

    作者信息 作者姓名:金云龙 个人站点:http://www.longestory.com 个人公众帐号:搜索"longestory"或"龙哥有话说" Servl ...

  5. 实现外网訪问局域网内的SVN——花生壳+visiualSVN实现外网訪问局域网内的SVN(三)

    经过前两篇文章.到眼下为止,我们已经获取了外网域名而且搭建好了SVN server.接下来,我们就总结一下怎样实践实现一下訪问局域网. 1.安装VisiualSVN Server(可见:http:// ...

  6. Tools-->SQL Server Profiler监视数据库

    http://www.cnblogs.com/lorking/p/4062787.html https://docs.microsoft.com/en-us/sql/tools/sql-server- ...

  7. 71.lambda表达式的递归

    #include <iostream> #include <functional> using namespace std; void main() { //&调用外部 ...

  8. Impala SQL

    不多说,直接上干货! 其实,跟hive差不多,大家可以去参考我写的hive学习概念系列. Impala SQL VS HiveQL 下面是Impala对基础数据类型和扩展数据类型的支持 • 此外,Im ...

  9. golang语言入门及安装

    golang语言入门及安装 go语言是google在2009年发布的开源编程语言使用Go编译的程序可以媲美C或C++代码的速度,而且更加安全.支持并行进程. 本次讲解在windows上安装go语言的开 ...

  10. reboot---重启Linux系统

    reboot命令用来重新启动正在运行的Linux操作系统. 语法 reboot(选项) 选项 -d:重新开机时不把数据写入记录文件/var/tmp/wtmp.本参数具有“-n”参数效果: -f:强制重 ...