赋值

字符串和数字

# id()函数可以获取变量在内存中的地址标识
num1 = 2;
num2 = 2;
print(id(num1))  # result:8791124202560
print(id(num2))  # result:8791124202560
str1 = '
str2 = '
print(id(str1))  # result:39986040
print(id(str2))  # result:39986040

结论:对于数字和字符串来说,赋值时如果有相同的值在python管理的内存中,python内部会把这个值的引用(地址)指向被赋值的变量

列表&字典&元组

 from copy import *
 list1 = [1, {'a': 1, 'b': 2}, ('a', 'b', 'c')]
 list2 = list1
 #列表
 print(id(list1))  # result:30433928
 print(id(list2))  # result:30433928
 #字典
 print(id(list1[1]))  # result:31017792
 print(id(list2[1]))  # result:31017792
 #元组
 print(id(list1[2]))  # result:35446576
 print(id(list1[2]))  # result:35446576

结论:对于赋值,列表,字典,元组用的都是同一块地址

浅拷贝

字符串和数字

 from copy import *
 str1 = '
 str2 = copy(str1)  # 使用copy模块里的copy()函数进行浅拷贝
 print(id(str1))  # result:31204496
 print(id(str2))  # result:31204496
 num1 = 3
 num2 = copy(num1)
 print(id(num1))  # rsult:8791078065248
 print(id(num2))  # rsult:8791078065248

结论:数字和字符串的浅拷贝,与赋值相同,在内存当中用的也是同一个地址

列表&字典&元组

 from copy import *
 list1 = [1, {'a': 1, 'b': 2}, ('a', 'b', 'c')]
 list2 = copy(list1)
 # 列表
 print(id(list1))  # result:42354568
 print(id(list2))  # result:42227400
 # 字典
 print(id(list1[1]))  # result:30952256
 print(id(list2[1]))  # result:30952256
 # 元组
 print(id(list1[2]))  # result:41082600
 print(id(list2[2]))  # result:41082600

 tuple1 = (1, {'a': 1, 'b': 2}, ['a', 'b', 'c'])
 tuple2 = copy(tuple1)
 # 元组
 print(id(tuple1))  # result:35668112
 print(id(tuple2))  # result:35668112
 # 字典
 print(id(tuple1[1]))  # result:30821256
 print(id(tuple2[1]))  # result:30821256
 # 列表
 print(id(tuple1[2]))  # result:35862792
 print(id(tuple2[2]))  # result:35862792

结论:对于列表和字典,浅拷贝会拷贝第一层引用(但最外层是元组时,不会拷贝).

深拷贝

字符串和数字

 from copy import *
 str1 = '
 str2 = deepcopy(str1)  # 使用copy模块里的copy()函数进行浅拷贝
 print(id(str1))  # result:31269752
 print(id(str2))  # result:31269752
 num1 = 3
 num2 = deepcopy(num1)
 print(id(num1))  # rsult:8791074002016
 print(id(num2))  # rsult:8791074002016

结论:无论是赋值或是浅拷贝亦或是深拷贝,字符串和数字都是用同一个地址

列表&字典&元组

 from copy import *
 list1 = [1, {'a': 1, 'b': 2}, [1, 2, 3], ('a', 'b', 'c')]
 list2 = deepcopy(list1)
 # 外层列表
 print(id(list1))  # result:32134984
 print(id(list2))  # result:32133768
 # 字典
 print(id(list1[1]))  # result:4410176
 print(id(list2[1]))  # result:31862720
 # 列表
 print(id(list1[2]))  # result:32262088
 print(id(list2[2]))  # result:32262408
 # 元组
 print(id(list1[3]))  # result:32038704
 print(id(list2[3]))  # result:32038704

结论:深拷贝会对列表和字典进行拷贝,但对于元组,深浅拷贝都会失效.

python基础(6)-深浅拷贝的更多相关文章

  1. python 基础之深浅拷贝

    深浅拷贝 s=[[1,2],'fgfgf','cx'] s3=s.copy() print(s) print(s3) 测试 D:\python\python.exe D:/untitled/dir/f ...

  2. Python基础:深浅拷贝

    对于数字.字符串深浅拷贝: import copy num = 0 copy_num = copy.copy(num) print("These are normal copy") ...

  3. 第五篇python进阶之深浅拷贝

    目录 第五篇python进阶之深浅拷贝 一.引言 1.1可变 和不可变 二.拷贝(只针对可变数据类型) 三.浅拷贝 四.深拷贝 第五篇python进阶之深浅拷贝 一.引言 1.1可变 和不可变 id不 ...

  4. 天啦噜!仅仅5张图,彻底搞懂Python中的深浅拷贝

    Python中的深浅拷贝 在讲深浅拷贝之前,我们先重温一下 is 和==的区别. 在判断对象是否相等比较的时候我们可以用is 和 == is:比较两个对象的引用是否相同,即 它们的id 是否一样 == ...

  5. Python 中的深浅拷贝

    Python 中的深浅拷贝 参考文献:https://blog.csdn.net/lnotime/article/details/81194633 参考文献:https://blog.csdn.net ...

  6. Python基础【3】:Python中的深浅拷贝解析

    深浅拷贝 在研究Python的深浅拷贝区别前需要先弄清楚以下的一些基础概念: 变量--引用--对象(可变对象,不可变对象) 切片(序列化对象)--拷贝(深拷贝,浅拷贝) 我是铺垫~ 一.[变量--引用 ...

  7. python——赋值与深浅拷贝

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

  8. 人生苦短之我用Python篇(深浅拷贝、常用模块、内置函数)

    深浅拷贝 有时候,尤其是当你在处理可变对象时,你可能想要复制一个对象,然后对其做出一些改变而不希望影响原来的对象.这就是Python的copy所发挥作用的地方. 定义了当对你的类的实例调用copy.c ...

  9. Python中的深浅拷贝

    1.什么是深浅拷贝? python中一切皆对象,python中的数字.字符串.元组等,如果存放在了内存中,这部分内存里面的内容是不会改变的,但是也有情况,内存中存放了可变对象,比如说列表和字典,他们的 ...

随机推荐

  1. Eclipse安装Git插件及简单操作

    0. 前言 说一件事,说起来也是好笑,工作三年半了,还没接触到团队开发,都是一个人小打小闹.因此连Git都没有使用过.感觉好Low的,这一篇,简单讲一下,Eclipse配置Git插件,并提交代码到Gi ...

  2. 【gulp】gulp + browsersync 构建前端项目自动化工作流

    什么是 gulp? gulp.js 是一个自动化构建工具,开发者可以使用它在项目开发过程中自动执行常见任务.gulp.js 是基于 node.js 构建的,利用 node.js 流的威力,你可以快速构 ...

  3. Java中Comparable和Comparator区别

    很好的一篇博客:http://blog.csdn.net/jq_ak47/article/details/61203817 http://www.cnblogs.com/cmxwt/p/6215253 ...

  4. 使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务

    在Spring Cloud Netflix栈中,各个微服务都是以HTTP接口的形式暴露自身服务的,因此在调用远程服务时就必须使用HTTP客户端.我们可以使用JDK原生的URLConnection.Ap ...

  5. minicom for Mac 配置

    安装:brew install minicom 配置: 串口是:dev/tty.usbserial minicons -s 配置一下: 流控要关掉,不然输入不了

  6. CentOS 6.8 防火墙配置

    系统: CentOS release 6.8 (Final) iptables v1.4.7 执行命令: #清除所有规则 iptables -F #开放redis端口 iptables -A INPU ...

  7. Tensorflow中神经网络的激活函数

    激励函数的目的是为了调节权重和误差. relu max(0,x) relu6 min(max(0,x),6) sigmoid 1/(1+exp(-x)) tanh ((exp(x)-exp(-x))/ ...

  8. 14.vue路由&脚手架

    一.vue路由:https://router.vuejs.org/zh/ 1.定义 let router = new VueRouter({ mode:"history/hash" ...

  9. ThreadPool study

    线程池浅析 线程池顾名思义就是放线程的池子 Thread Pool. 那么为什么要有线程池呢?有些时候系统需要处理非常多的执行时间很短的请求,如果每一个请求都开启一个新的线程,则系统创建销毁线程的开销 ...

  10. java web实现在cookie中保存用户名和密码,用户自动登入

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...