python开发_copy(浅拷贝|深拷贝)_博主推荐

python中,有着深拷贝和浅拷贝,即copy模块

下面我们就来聊一下:

运行效果:

==================================================

代码部分:

==================================================

 1 #python copy
 2 '''
 3 个人认为:
 4     浅拷贝:拷贝后,对象的引用没有发生变化,而对象的行为发生变化,会反映到拷贝后的对象身上
 5     深拷贝:拷贝后,对象的引用发生了变化,即对象不同,所以,即使对象再怎么变,也不会对其他对象产生影响
 6 '''
 7 
 8 import copy
 9 
10 def shallow_copy(s):
11     '''make a shallow copy of s.'''
12     return copy.copy(s)
13 
14 def deep_copy(d):
15     '''make a deep copy of d.'''
16     return copy.deepcopy(d)
17 
18 def test_shallow():
19     tem_data = ['a', 'c', 'e', 't', [1, 2, 3]]
20     print('被拷贝的源数据为:{}'.format(tem_data))
21     s_copy = shallow_copy(tem_data)
22     print('进行浅拷贝....')
23     tem_data.append('Hongten')
24     tem_data[4].append('4')
25     print('修改源数据后:{}'.format(tem_data))
26     print('拷贝后的数据为:{}'.format(s_copy))
27 
28 def test_deep():
29     tem_data = ['a', 'c', 'e', 't', [1, 2, 3]]
30     print('被拷贝的源数据为:{}'.format(tem_data))
31     s_copy = deep_copy(tem_data)
32     print('进行深拷贝....')
33     tem_data.append('Hongten')
34     tem_data[4].append('4')
35     print('修改源数据后:{}'.format(tem_data))
36     print('拷贝后的数据为:{}'.format(s_copy))
37 
38 def test_s_copy():
39     '''listB复制了listA,这时候listB是对listA的一个引用
40     他们指向的是同一个对象:[1, 2, 3, 4, 5],当我们试图修
41     改listB[1] = 'Hongten'的时候,listB的所指向的对象的
42     行为发生了变化,即元素的值发生了变化,但是他们的引用是没
43     有变化的,所以listA[1] = 'Hongten'也是情理之中的事'''
44     listA = [1, 2, 3, 4, 5]
45     listB = listA
46     listB[1] = 'Hongten'
47     print('listA = {}, listB = {}'.format(listA, listB))
48 
49 def test_clone():
50     '''进行了列表的克隆操作,即拷贝了另一个列表,这样的操作,
51     会创造出新的一个列表对象,使得listA和listB指向不同的对象,
52     就有着不同的引用,所以当listB[1] = 'Hongten'的时候,
53     listA[1]还是等于2,即不变'''
54     listA = [1, 2, 3, 4, 5]
55     listB = listA[:]
56     listB[1] = 'Hongten'
57     print('listA = {}, listB = {}'.format(listA, listB))
58 
59 def main():
60     print('浅拷贝Demo')
61     test_shallow()
62     print('#' * 50)
63     print('深拷贝Demo')
64     test_deep()
65     print('#' * 50)
66     test_s_copy()
67     print('#' * 50)
68     test_clone()
69 
70 if __name__ == '__main__':
71     main()

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏武军超python专栏

2018-7-18pythoh中函数的参数,返回值,变量,和递归

********************************************************************************...

1334
来自专栏程序员互动联盟

【专业技术第十二讲】void的妙用

存在问题: 遇到微信好友询问关于void *的用法,这里做一个总结性的回复。 解决方案: void的字面意思是空类型,void *的意思是空类型指针,void ...

36510
来自专栏C/C++基础

C++模板之隐式实例化、显示实例化、隐式调用、显示调用和模板特化详解

模板的实例化指函数模板(类模板)生成模板函数(模板类)的过程。对于函数模板而言,模板实例化之后,会生成一个真正的函数。而类模板经过实例化之后,只是完成了类的定义...

1702
来自专栏决胜机器学习

《Redis设计与实现》读书笔记(五) ——Redis中的整数集合

《Redis设计与实现》读书笔记(五) ——Redis中的整数集合 (原创内容,转载请注明来源,谢谢) 一、概述 整数集合(intset)是redis数据结构集...

3484
来自专栏北京马哥教育

17个案例带你3分钟搞定Linux正则表达式

正则表达式是一种字符模式,用于在查找过程中匹配制定的字符。 元字符通常在Linux中分为两类: Shell元字符,由Linux Shell进行解析; 正则表达式...

3534
来自专栏风中追风

try,finally中都有return时程序的执行顺序

 在Java中当try、finally语句中包含return语句时,执行情况到底是怎样的,finally中的代码是否执行,大家各有各的说法,刚好今天有个朋友问了...

37015
来自专栏nummy

python双端队列deque

由于deque是一种序列容器,因此同样支持list的一些操作,如用getitem()检查内容,确定长度,以及通过匹配标识从序列中间删除元素。

842
来自专栏C语言及其他语言

[蓝桥杯]字符逆序

题目描述 将一个字符串str的内容颠倒过来,并输出。str的长度不超过100个字符。 输入 输入包括一行。 第一行输入的字符串。 输出 输出转换好的逆序字符串。...

3525
来自专栏java小白

LinkedHashMap的accessOrder

1989
来自专栏流媒体

C++ string

852

扫码关注云+社区

领取腾讯云代金券