Day 7 深copy和浅Copy
dict.fromkeys的用法
1
2
3
4
5
6
7
8
9
10
11
|
#dict.fromkeys的用法 #例子1 dic = dict .fromkeys([ 1 , 2 , 3 ],[]) print (dic) #{1: [], 2: [], 3: []} dic[ 2 ].append( 'alex' ) #{1: ['alex'], 2: ['alex'], 3: ['alex']} print (dic) #例子二 dic1 = dict .fromkeys([ 'Q' , 'w' ],[ 'a' , 'b' ]) print (dic1) #{'Q': ['a', 'b'], 'w': ['a', 'b']} dic1[ 'w' ].append( 'd' ) print (dic1) #{'Q': ['a', 'b', 'd'], 'w': ['a', 'b', 'd']} |
浅copy和深copy
浅copy的引入:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
引入浅copy #只是第一层的列表变化 l1 = [ 1 , 2 , 3 ] l2 = l1[:] l1.append( 123 ) print (l1) #[1, 2, 3, 123] print (l2) #[1, 2, 3] #第二层列表改变 l3 = [ 1 ,[ 2 , 3 ], 4 ] l4 = l3[:] #实质上是浅copy l3[ 1 ].append( 666 ) print (l3) #[1, [2, 3, 666], 4] print (l4) #[1, [2, 3, 666], 4] |
浅copy:
1
2
3
4
5
6
7
|
#浅copy #对于浅copy来说,第一层都是独立的内存地址,从第二层开始都是指向同一个内存地址,一变全都变。 l5 = [ 9 , 8 ,[ 7 , 6 ], 5 ] l6 = l5.copy() l5[ 2 ].append( 888 ) print (l5, id (l5), id (l5[ 2 ])) #[9, 8, [7, 6, 888], 5] 31820816 31820856 print (l6, id (l6), id (l6[ 2 ])) #[9, 8, [7, 6, 888], 5] 31819336 31820856 |
深copy:
1
2
3
4
5
6
7
8
|
#深copy #对于深copy来说,无论多少层,在内存中,都是两个独立的内存地址。 import copy l7 = [ 9 , 8 ,[ 7 , 6 ], 5 ] l8 = copy.deepcopy(l7) l7[ 2 ].append( 888 ) print (l7, id (l7), id (l7[ 2 ])) #[9, 8, [7, 6, 888], 5] 41955896 41955816 print (l8, id (l8), id (l8[ 2 ])) #[9, 8, [7, 6 ], 5] 41957976 41957936
|
Day 7 深copy和浅Copy的更多相关文章
- (五)聊一聊深Copy与浅Copy
一.关于浅copy与深copy 首先说明一下: 在python中,赋值其实就是对象的引用,变量就是对象的一个标签,如果把内存对象比喻成一个个房间,那么变量就是门牌号. 深copy与浅copy只是针对可 ...
- Python的深copy和浅copy
浅拷贝(copy):拷贝父对象,不会拷贝对象的内部的子对象. 深拷贝(deepcopy): copy 模块的 deepcopy 方法,完全拷贝了父对象及其子对象. 浅copy: a = [1, 2, ...
- 列表的使用2,深COPY和浅COPY,循环列表,步长切片
name2=names.copy() 下面我看几种奇怪的现象: 首先把源列表copy以后,把源列表第2个数值修改.那么没毛病. 如果源列表里,还包含了一个子列表:这也没毛病 如果我们这个时候修改子列表 ...
- 深copy和浅copy
浅copy:其实就是将容器中的内存地址存放进另一个容器中,所以两个容器本身的内存地址不相同,但容器里面的内存地址相同 代码如下: 深copy:就是从里到外完完全全复制了所有值,存进另外的内存空间,并赋 ...
- python中深copy,浅copy与赋值语句的区别
以下详细讲解:python深复制,浅复制与赋值语句的区别 1. '='赋值语句,常规复制只是将另一个变量名关联到了列表,并不进行副本复制,实例如下: var1=[12,35,67,91,101]var ...
- C/C++深度copy和浅copy
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include<string. ...
- 深浅copy和浅copy
深浅copy 1,先看赋值运算. l1 = [1,2,3,['barry','alex']] l2 = l1 l1[0] = 111 print(l1) # [111, 2, 3, ['barry', ...
- python中深copy,浅copy
版权声明:本文为博主原创文章,未经博主允许不得转载. >>> mylist1 = [1, 2, 3, 4] >>> myl = mylist1 >>&g ...
- PHP的深copy和浅copy
1.对象复制的由来 为什么对象会有“复制”这个概念,这与PHP5中对象的传值方式是密切相关的,让我们看看下面这段简单的代码 /** * 电视机类 */ class Television { /** * ...
随机推荐
- 算法笔记_067:蓝桥杯练习 算法训练 安慰奶牛(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 Farmer John变得非常懒,他不想再继续维护供奶牛之间供通行的道路.道路被用来连接N个牧场,牧场被连续地编号为1到N.每一个牧场都是 ...
- (三)介绍简单的ROS命令
1.ROS文件系统中的基本概念 Packages: Package是ROS系统中最底层最基本的组织,里面存放各种文件:库.工具.可执行文件等.Manifest: 一个package描述xml文件,定义 ...
- springMVC使用@RequestParam用于处理简单类型的绑定
使用@RequestParam常用于处理简单类型的绑定. value:参数名字,即入参的请求参数名字,如value=“item_id”表示请求的参数区中的名字为item_id的参数的值将传入: req ...
- 骗分大法之-----分块||迷之线段树例题a
什么是分块呢? 就是一种可以帮你骗到不少分的神奇的算法. 分块的写法有几种,我所知道的有①预处理②不预处理 不预处理的代码我看得一脸懵逼 所以我在这里就谈一下预处理的版本www 首先看一道题: 给定一 ...
- 低配NOSQL
东西写的太简单了 都不好意思说是NOSQL 其实就是STL 的map容器记录了写入的信息 解析了下数据仅此. 分析的时候想了很多 比如学习redis的自写hash,动态调整hash表容量. 比如右值或 ...
- 前端之JavaScript笔记2
一 数组对象 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...
- window server2012服务器上如何安装nginx并启动
window环境下,Nginx安装启动的步骤如下: 把下载的window下的安装包,解压到一个不包含空格的路径下,比如:d:/Nginx 打开命令行窗口[win+R 输入cmd,然后确定]. 进入解压 ...
- 2018.09.16 spoj104Highways (矩阵树定理)
传送门 第一次写矩阵树定理. 就是度数矩阵减去邻接矩阵之后得到的基尔霍夫矩阵的余子式的行列式值. 这个可以用高斯消元O(n3)" role="presentation" ...
- bootstrap模态框的调用
1.<a href="JavaScript:void(0);" class="bs-tooltip remark-item" rel="{$bi ...
- hdu-1877(大数+进制转换)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1877 思路:注意考虑0,0的情况. #include<iostream> #include ...