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的深浅拷贝-成为马老师的弟子
参考链接 骏马金龙 前提 想要了解深浅拷贝之前必须要知道可变和不可变类型,和他们的特性 不可变类型 数字 字符串 元组 不可变集合 特性:改变值,会创建新的内存空间存储数据 可变类型 列表 字典 可变 ...
随机推荐
- Delphi编写系统服务:完成端口演示
在开发大量Socket并发服务器,完成端口加重叠I/O是迄今为止最好的一种解决方案,下面是简单的介绍: “完成端口”模型是迄今为止最为复杂的一种I/O模型,特别适合需要同时管理为数众多的套接字,采 ...
- asp.net mvc实现微信外H5支付方法
一.微信支付方式介绍 微信提供了各种支付方式,试用于各种不同的支付场景,主要有如下几种: 1.刷卡支付 刷卡支付是用户展示微信钱包内的“刷卡条码/二维码”给商户系统扫描后直接完成支付的模式.主要应用线 ...
- CentOS7 Vim自动补全插件----YouCompleteMe安装与配置
最近刚装了新系统CentOS7,想要把编码环境配置一下,使用Vim编写程序少不了使用自动补全插件,我以前用的是neocomplcache+code_complete+omnicppcomplete.但 ...
- kubernetes实战篇之nexus oss服务器部署及基于nexus的docker镜像仓库搭建
系列目录 Nexus oss仓库管理平台搭建 Nexus是一款仓库管理工具,支持Npm,bower,maven,nuget,apt,yum甚至docker,helm等各种仓库,说的通俗以下,就是私服镜 ...
- 《Spring Cloud》学习(一) 服务治理!
前言:之前网上学习过Spring Cloud,对于工作上需要是足够了,总归对于一些方面一知半解,最近难得有些闲暇时间,有幸读了崔永超先生的<Spring Cloud 微服务实战>,一方面记 ...
- iOS App开发的那些事儿1:如何建立合适的规范
<iOS App开发的那些事儿>系列文章从更宏观的角度出发,不仅仅局限于具体某个功能.界面的实现,而是结合网易云信iOS端研发负责人多年的经验,从如何优化现有代码的角度出发,深度分析如何创 ...
- 微服务之服务注册与发现--Consul(转载)
http://blog.csdn.net/buxiaoxia/article/details/69788114 https://www.cnblogs.com/xiaohanlin/p/8016803 ...
- spring源码深度解析— IOC 之 自定义标签解析
概述 之前我们已经介绍了spring中默认标签的解析,解析来我们将分析自定义标签的解析,我们先回顾下自定义标签解析所使用的方法,如下图所示: 我们看到自定义标签的解析是通过BeanDefinition ...
- docker安装gitlab-runner
docker安装gitlab-runner docker pull gitlab/gitlab-runner:latest安装gitlab-runner 打开自己搭建的GitLab网站,点击顶栏的Sn ...
- HTML5新增的表单验证功能
一.HTML5表单的特点: HTML5 表单增加了许多内置的控件和控件属性 XHTML 中需要放在 form 之中的诸如 input/button/select/textarea 等标签元素,在 HT ...