python 的深浅拷贝问题
深浅拷贝概念
基本类型和引用类型数据拷贝的问题。因为基本类型的数据大小是固定的,所以他保存在栈内存中;而引用类型的数据大小不固定,因而保存在堆内存中,单引用类型在栈内存中只保存一个指向堆内存的指针。
浅拷贝:
对于浅拷贝来说,如果拷贝基本类型,那么就等于赋值一样,会直接拷贝其本身;但如果拷贝的是引用类型,就只会拷贝一层,如果 原对象发生改变,那么拷贝对象也会发生改变。
深拷贝:
深拷贝的话就会拷贝多层,嵌套的对象也会被拷贝出来,相当于开辟一个新的内存地址用于存放拷贝的对象。
在python语言中没有明显的指出,例如,操作指针或对于指针的操作。
在java或者go中是可以的。
业务需求
抓取交易所黄金的k线,进行数据分析。
问题代码
import datetime
def judgment(info):
minute = datetime.timedelta(minutes=15)
count = 0
while True:
Long = len(info)
if count + 1 == Long:
break
if info[count]["TS"] + minute == info[count + 1]["TS"]:
pass
else:
date = info[count]
date["TS"] = info[count]["TS"] + minute
info.insert(count + 1, date)
count += 1
return info
info = [{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 2, 45), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561338900', 'TS': datetime.datetime(2019, 6, 22, 5, 15), 'P': '313.88', 'L': '313.03',
'H': '314.97', 'O': '313.30'}]
print(len(info))
date = judgment(info)
print(date)
date1 = [{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561338900', 'TS': datetime.datetime(2019, 6, 22, 5, 15), 'P': '313.88', 'L': '313.03',
'H': '314.97', 'O': '313.30'}]
可以发现代码逻辑是没有问题的,问题出在深浅拷贝的问题。按照正常的逻辑他的值会进行替换,而不是出现错误。一个简单的问题弄了一下午,汗颜。
import datetime
import copy
def judgment(info):
minute = datetime.timedelta(minutes=15)
count = 0
info_date = []
while True:
Long = len(info)
if count + 1 == Long:
break
if info[count]["TS"] + minute == info[count + 1]["TS"]:
pass
else:
date = info[count]
date["TS"] = info[count]["TS"] + minute
info.insert(count + 1, date)
# print(info[count])
info_date.append(copy.deepcopy(info[count]))
count += 1
return info_date
info = [{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 2, 45), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561338900', 'TS': datetime.datetime(2019, 6, 22, 5, 15), 'P': '313.88', 'L': '313.03',
'H': '314.97', 'O': '313.30'}]
print(len(info))
date = judgment(info)
print(date)
date1 = [{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 3, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 3, 15), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 3, 30), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 3, 45), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 4, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 4, 15), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 4, 30), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 4, 45), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'},
{'C': 'AUTD', 'T': '1561142700', 'TS': datetime.datetime(2019, 6, 22, 5, 0), 'P': '312.10', 'L': '312.10',
'H': '312.10', 'O': '312.10'}]
总结:Python是没有基础数据类型(primitive value type),全部都是对象.也就意味着变量和属性全部都是引用类型.
为了提醒大家所以讲问题整理出来。在写程序的时候需要注意,深浅拷贝问题,有时候我们往往忽略最简单的问题。
python 的深浅拷贝问题的更多相关文章
- Python原理 -- 深浅拷贝
python原理 -- 深浅拷贝 从数据类型说开去 str, num : 一次性创建, 不能被修改, 修改即是再创建. list,tuple,dict,set : 链表,当前元素记录, 下一个元素的位 ...
- Python的深浅拷贝
Python的深浅拷贝 深浅拷贝 1. 赋值,对于list, set, dict来说, 直接赋值. 其实是把内存地址交给变量并不是复制一份内容 list1 = [']] list2 = list1 p ...
- 24、简述Python的深浅拷贝以及应用场景
深浅拷贝的原理 深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:copy.deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝 ...
- Python入门-深浅拷贝
首先我们在这里先补充一下基础数据类型的一些知识: 一.循环删除 1.前面我们学了列表,字典和集合的一些操作方法:增删改查,现在我们来看一下这个问题: 有这样一个列表: lst = ['周杰伦','周润 ...
- day2学python 数据类型+深浅拷贝+循环
数据类型+深浅拷贝+循环 别的语言的数组 python不用定义 直接使用 color=['红','橙','黄','绿','青','蓝','紫'] print(color[1:3]) //打印[1,3) ...
- 简述Python的深浅拷贝以及应用场景
深浅拷贝的原理 深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:copy.deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝 ...
- python 赋值 深浅拷贝
深浅拷贝 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 impor ...
- Python随笔---深浅拷贝
Python中为了避免某些方法的副作用(拷贝后有时更改原有数据),故存在有深浅拷贝的存在 浅拷贝导入copy方法集,使用copy_copy的方法进行 深拷贝一样导入copy方法集,使用copy_dee ...
- python的深浅拷贝-成为马老师的弟子
参考链接 骏马金龙 前提 想要了解深浅拷贝之前必须要知道可变和不可变类型,和他们的特性 不可变类型 数字 字符串 元组 不可变集合 特性:改变值,会创建新的内存空间存储数据 可变类型 列表 字典 可变 ...
随机推荐
- 算法之--字符串反转【python实现】
题目描述 给定一个字符串,要求把字符串前面的若干个字符移动到字符串的尾部,如把字符串“abcdef”前面的2个字符'a'和'b'移动到字符串的尾部,使得原字符串变成字符串“cdefab”.请写一个函数 ...
- 【转】python Counter模块
>>> c = Counter() # 创建一个新的空counter >>> c = Counter('abcasdf') # 一个迭代对象生成的counter & ...
- win10应用开发——如何判断应用是在手机上运行还是电脑上运行
原文:win10应用开发--如何判断应用是在手机上运行还是电脑上运行 在进行uwp应用开发的时候, 有时我们需要知道自己的应用是在手机端运行还是在桌面端运行,那么通过以下的api就可以进行判断: Wi ...
- uwp开发:数据绑定——值转换器 的简单使用
原文:uwp开发:数据绑定--值转换器 的简单使用 今天,我在做最近正在开发的“简影”uwp应用时遇到一个问题,其中有个栏目,叫做“画报”,是分组显示一组一组的 图片,每组图片在界面上只显示9个,点击 ...
- 中国2017 Google 开发者大会第一天简单回顾
昨天有幸参加了中国2017 Google 开发者大会,在这第一天就收获满满,昨天太忙了,今天早晨来一起简单回顾一下,可以让没有参加的童鞋们感受一下现场的温度. 早早就来到了会议现场,外面看不出什么特别 ...
- 在asp.net 中web.config配置错误页
每当用户访问错误页面时,会出现不友好的错误页面,所以为了防止这种不友好,我们在web.config中的<system.web>节点下配置 <customErrors>,在出现比 ...
- storm和kafka的wordCount
这个是在window环境下面安装的kafka 下载pom依赖 <dependency> <groupId>org.apache.storm</groupId> &l ...
- 用TTcpClient和TTcpServer进行文件的传输
发送数据时有Sendln,SendBuf,SendStream.接收数据时有Receiveln,ReceiveBuf,当时我很奇怪为什么没有ReceiveStream.因为很自然的想到是对应关系的.但 ...
- 使用Boost的DLL库管理动态链接库
Boost 1.61新增了一个DLL库,跟Qt中的QLibrary类似,提供了跨平台的动态库链接库加载.调用等功能.http://www.boost.org/users/history/version ...
- Delphi产生任务栏图标【TNotifyIconData】
一.新建一个应用程序:File->New Applicaton 在Interface部分要放在Uses Message之后,定义一个消息常量:const WM_NID=WM_USER+1000; ...