1.python中深拷贝和浅拷贝的理解

  自己理解:浅拷贝,只是拷贝引用,不开辟新的空间存储拷贝内容。

       深拷贝,就是在内存中,开辟一个新的内存地址,将拷贝内容放到新的地址中去。

  验证:对于数字,字符串,元祖这种不可变类型的数据,深拷贝和浅拷贝拷贝的是内存地址的引用。

  不可变类型

import copy


# 不可变类型---数值 int float
a1 = 1
b1 = copy.copy(a1)
print(id(a1))  # 8791199896608
print(id(b1))  # 8791199896608
c1 = copy.deepcopy(a1)
print(id(c1))  # 8791199896608
d1 = a1
print(id(d1))  # 8791199896608


# 不可变类型---元祖
a2 = (1,2)
b2 = copy.copy(a2)
print(id(a2)) # 35120520
print(id(b2)) # 35120520
c2 = copy.deepcopy(a2)
print(id(c2)) # 35120520
d2 = a2
print(id(d2)) # 35120520


# 不可变类型---字符串
a3 = "china"
b3 = copy.copy(a3)
print(id(a3)) # 43407152
print(id(b3)) # 43407152
c3 = copy.deepcopy(a3)
print(id(c3)) # 43407152
d3 = a3
print(id(d3)) # 43407152

  可变类型:字典,列表

a1 = [1,2,3]
b1 = copy.copy(a1)
print(id(a1)) # 43298888  
print(id(b1)) # 43270024
c1 = copy.deepcopy(a1)
print(id(c1)) # 43299144
d1 = a1
print(id(d1)) # 43298888

 图像理解浅拷贝:浅拷贝是在内存中创建了一个新的内存地址,用来存放新的列表,b指向这个列表,所以a和b在内存中的地址不一样。因此说浅拷贝只是拷贝了列表这个对象,而不是里面的数据。

 

  如何证明,浅拷贝只是拷贝了对象,而不是里面的内容呢?

a1 = [1,2,3]
b1 = copy.copy(a1)
print(id(a1)) #
print(id(b1)) #
for i in a1:
print(id(i)) 8791195833376
8791195833408
8791195833440 for i in b1:
print(id(i)) 8791195833376
8791195833408
8791195833440

  所以打印a1和b1的内存地址不同,但是结果却相同。

print(a1)
print(b1)
[1, 2, 3]
[1, 2, 3]

  另一种方式证明,浅拷贝只是拷贝对象,而里面的数据还是指向原来对象的数据。

import copy

a1 = [1,2,3,[4,5,6]]
b1 = copy.copy(a1)
print(a1)
print(b1) [1, 2, 3, [4, 5, 6]]
[1, 2, 3, [4, 5, 6]] a1[3].append(4) # 也就是说b1里面下标为3的元素是指向a1里面下标为3的元素,所以才会打印出一样的效果。
print(a1)
print(b1) [1, 2, 3, [4, 5, 6, 4]]
[1, 2, 3, [4, 5, 6, 4]]

  下面的例子也直接能证明这一点

import copy

a1 = [1,2,3]
b1 = copy.copy(a1)
print(a1)
print(b1) [1, 2, 3]
[1, 2, 3] a1.append(4) # 此时a1中有四个元素,此时b1中只有三个元素,b1中没有第四个元素指向a1中新的元素,所以打印结果如下。
print(a1)
print(b1) [1, 2, 3, 4]
[1, 2, 3]

  python中产生浅拷贝效果的地方:

    1.列表的切片

a = [1,2,3,4,5,7,8,9,10]
b = a[1:5]
print(a)
print(b) [1, 2, 3, 4, 5, 7, 8, 9, 10]
[2, 3, 4, 5] a[1] = "" # a 中下标为1的元素新建立了一个内存地址,存储的是"1"
a[2] = ""
a[3] = ""
a[4] = ""
print(a)
print(b) # b 中下标为1的元素指向的是原来这个数据1在内存中的地址。 [1, '', '', '', '', 7, 8, 9, 10]
[2, 3, 4, 5]

    2. 使用copy模块中的copy()函数

 图像理解浅拷贝:

import copy
a = [1,2,3,[4,5,6]] # 对于不可变类型,深拷贝也只是拷贝引用,但是对于可变类型[4,5,6],深拷贝会拷贝一个新的对象,多以id值不一样,那么当[4,5,6]的数据进行增加时,深拷贝的后的对象会发生变化吗?
b = copy.deepcopy(a)
print(id(a))
print(id(b)) 43138824
43167944 for i in a:
print(id(i)) 8791199896608
8791199896640
8791199896672
43138952 for i in b:
print(id(i)) 8791199896608
8791199896640
8791199896672
43204232
import copy
a = [1,2,3,[4,5,6]]
b = copy.deepcopy(a) print(a)
print(b) [1, 2, 3, [4, 5, 6]]
[1, 2, 3, [4, 5, 6]]
# 当a[3]中的元素进行增加数量时,因为深拷贝后列表中的第三个元素指向发生了变化,重新生成了一个列表,指向了新列表,所以,原列表增加,新列表不增加。但是列表中的元素,还是指向原来列表中的元素。
a[3].append(7) 

print(a)
print(b) [1, 2, 3, [4, 5, 6, 7]]
[1, 2, 3, [4, 5, 6]] for i in a[3]:
print(id(i)) 8791199896704
8791199896736
8791199896768
8791199896800 for i in b[3]:
print(id(i)) 8791199896704
8791199896736
8791199896768

# TODO 字典

# TODO 元祖

总结:

  • Python中对象的赋值都是进行对象引用(内存地址)传递
  • 使用copy.copy(),可以进行对象的浅拷贝,它复制了对象,但对于对象中的元素,依然使用原始的引用.
  • 如果需要复制一个容器对象,以及它里面的所有元素(包含元素的子元素),可以使用copy.deepcopy()进行深拷贝
  • 对于非容器类型(如数字、字符串、和其他'原子'类型的对象)没有被拷贝一说
  • 如果元祖变量只包含原子类型对象,则不能深拷贝

python基础面试题总结的更多相关文章

  1. python基础面试题整理---从零开始 每天十题(01)

    最近在弄flask的东西,好久没写博客的,感觉少了点什么,感觉被别人落下好多,可能渐渐的养成了写博客的习惯吧.也是自己想学的东西太多了(说白了就是基础太差了,只是know how,不能做到konw w ...

  2. Python基础面试题库

    Python基础面试题库   Python是一门学习曲线较为容易的编程语言,随着人工智能时代的到来,Python迎来了新一轮的高潮.目前,国内知乎.网易(游戏).腾讯(某些网站).搜狐(邮箱).金山. ...

  3. python基础面试题整理---从零开始 每天十题(02)

    书接上回,我们继续来说说python的面试题,我在各个网站搜集了一些,我给予你们一个推荐的答案,你们可以组织成自己的语言来说出来,让我们更好的做到面向工资编程 一.Q:说说你对zen of pytho ...

  4. python基础面试题(全网最全!)

    目录 1.为什么学习Python? 2.通过什么途径学习的Python? 3.Python和Java.PHP.C.C#.C++等其他语言的对比? 4.简述解释型和编译型编程语言? 5.Python解释 ...

  5. python基础面试题30问(附带答案)

    1.     闭包 定义:闭包是由函数及其相关的引用环境组合而成的实体(即:闭包=函数+引用环境)(想想Erlang的外层函数传入一个参数a, 内层函数依旧传入一个参数b, 内层函数使用a和b, 最后 ...

  6. Python基础面试题整理

    基础 Python中lambda是什么意思 Python中的pass是什么意思 作为解释型语言,Python如何运行 什么是Python的单元测试 在Python中unittest是什么 如何将数字转 ...

  7. python基础面试题1

    Python面试重点(基础篇) 注意:只有必答题部分计算分值,补充题不计算分值. 第一部分 必答题(每题2分) 简述列举了解的编程语言及语言间的区别? c语言是编译型语言,运行速度快,但翻译时间长py ...

  8. python基础面试题(一)

    1.   简述Python代码的运行机制 1.把原始代码编译成字节码         编译后的字节码是特定于Python的一种表现形式,它不是二进制的机器码,需要进一步编译才能被机器执行. 2.把编译 ...

  9. python基础面试题整理---从零开始 每天十题(04)

    一.Q:如何用Python来进行查询和替换一个文本字符串? A:可以使用sub()方法来进行查询和替换,sub方法的格式为:sub(replacement, string[, count=0]) re ...

  10. python基础面试题整理---从零开始 每天十题(03)

    一.Q:用Python输出一个Fibonacci数列?(斐波那契额数列) A:我们先来看下代码 #!/usr/bin/env python # -*- coding: utf-8 -*- def fi ...

随机推荐

  1. [USACO17FEB]Why Did the Cow Cross the Road III G (树状数组,排序)

    题目链接 Solution 二维偏序问题. 现将所有点按照左端点排序,如此以来从左至右便满足了 \(a_i<a_j\) . 接下来对于任意一个点 \(j\) ,其之前的所有节点都满足 \(a_i ...

  2. linux vim设置和 快捷命令配置

    1.vim配置 set tabstop= set shiftwidth= set softtabstop= set fileencodings=utf-,ucs-bom,gb2312,gbk,gb18 ...

  3. QGIS SDK下载

    https://www.e-learn.cn/content/qita/1241748 基于OSGEO4W下载lib包. 并在VS中调用. 这样比直接编译容易一些.可以快速上手.

  4. Jesus Is Here

    Jesus Is Here Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 65535/102400 K (Java/Others)To ...

  5. 台哥原创:java 俄罗斯方块源码

    大四的时候,用java开发,耗时一周 界面参照当时用的联想手机里的俄罗斯方块 ​ 这里的级别,标识难度,1是初级,方块下降速度很慢,5是最高级,下降速度最快 ​ 得分:每消除一行,会给10分,同时消除 ...

  6. C# 高性能 TCP 服务的多种实现方式Cowboy.Sockets

      本篇文章的主旨是使用 .NET/C# 实现 TCP 高性能服务的不同方式,包括但不限于如下内容: APM 方式,即 Asynchronous Programming Model TAP 方式,即 ...

  7. Spring 注解配置 WebApplicationContext

    https://docs.spring.io/spring-framework/docs/4.3.9.RELEASE/spring-framework-reference/htmlsingle/#be ...

  8. php脚本超时时间设置

    设置PHP脚本执行超时的时间有下面这样一些方法:php.ini 中缺省的最长执行时间是 30 秒,这是由 php.ini 中的 max_execution_time 变量指定,倘若你有一个需要颇多时间 ...

  9. Docker安装Web前端性能测试工具Sitespeed.io

    一.Sitespeed.io概述 1.Sitespeed.io简介 Sitespeed.io:是一款开源的Web性能测试工具,用来衡量Web网站的综合性能,帮助开发和测试人员分析网页的加载速度和渲染性 ...

  10. 京东商品评论的分类预测与LSA、LDA建模

    (一)数据准备 1.爬取京东自营店kindle阅读器的评价数据,对数据进行预处理,使用机器学习算法对评价文本进行舆情分析,预测某用户对本商品的评价是好评还是差评.通过数据分析与模型分析,推测出不同型号 ...