day06 内存地址 小数据池缓存机制
1. 内存相关
示例一
v1=[11,22,33]
v2=[11,22,33]
#值相等 内存地址不等 v1=11
v2=11
#按理说内存地址应该不等,但是python为了优化使其内存地址相等 v1="dd"
v2="dd"
#按理说内存地址应该不等,但是python为了优化使其内存地址相等
示例二
v1=[11,22,33]
v1=[11,22]#第一个值将会等待被回收,另外再开辟内存地址
示例三
v1=[11,22,33]
v2=v1# v2指向v1指向的地址 #练习1
v1=[11,22,33]
v2=v1#v2指向v1指向的地址
v1.append(666)#在v1指向的内存地址中修改内容
print(v2)#v2还是指向v1指向的地址
#[11,22,33,666] #2
v1=[11,22,33]
v2=v1#v2指向v1指向的地址
v1=[1,2,3,4]#v1重新开辟一块内存空间
print(v2)#v2还是指向原来v1指向的地址 address([11,22,33])
#[11,22,33] #3.
v1="mari"
v2=v1#v2指向v1指向的地址
v1="old"
print(v2)
#mari
示例四
v=[1,2,3]
values=[11,2,v] #values[2]指向v指向的内存地址
#1.内部修改
v.append(9)
print(values)#[11,2,[1,2,3,9]] #2.内部修改
values[2].append(999)# values[2]==v 修改v内存地址的内容
print(v)#
[1,2,3,999] #3.赋值
values[2]=666
#将values[2]不再指向v 而是新赋值666 重新开辟内存空间 所以对v没有影响
print(v)
#[1,2,3]示例五
v1 = [1,2]
v2 = [2,3]
v3 = [11,22,v1,v2,v1]
示例6
#20.看代码写结果并解释原因 # info = [1,2,3]
# userinfo = [info,info,info,info,info]
#
# info[0] = '不仅多,还特么难呢'
# print(info,userinfo)
#['不仅多,还特么难呢', 2, 3] (列表修改后 自身改变 可变数据类型)
#[['不仅多,还特么难呢', 2, 3], ['不仅多,还特么难呢', 2, 3], ['不仅多,还特么难呢', 2, 3], ['不仅多,还特么难呢', 2, 3], ['不仅多,还特么难呢', 2, 3]]
#(userinfo指向info指向的地址,info只是修改了内存地址中的一个元素,并没有改变地址,info的地址中内容改变,userinfo的内容也会跟着内存地址中内容变化而变化) #24.看代码写结果并解释原因 # data_list = []
# data = {}
# for i in range(10):
# data['user'] = i
# data_list.append(data)
# print(data_list) #[{'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}]
#data的内存地址中的值最后都被9覆盖
#data_list里面保存的是十个相同的data内存地址 #25.看代码写结果并解释原因 # data_list = []
# for i in range(10):
# data = {}
# data['user'] = i
# data_list.append(data)
# print(data_list)
#[{'user': 0}, {'user': 1}, {'user': 2}, {'user': 3}, {'user': 4}, {'user': 5}, {'user': 6}, {'user': 7}, {'user': 8}, {'user': 9}]
#data字典创建了10次-->10个不同的内存地址-->每创建一次地址就赋一个i值(i每次都会自加一次)然后将十个不同内存地址添加到列表data_list中
# 所以i不会被覆盖
#所以打印的就是10个内存地址中的值 #1.列表中存放的是很多个地址的,每个地址指向存放该元素的另一个内存地址
data=[1,2,3,4]
nums=[]
for i in data:
nums.append(i)#将data列表的地址存放到num列表中
print(id(data[0]),id(nums[0]))#所以每个列表中子元素的地址都相等,但是nums和data的地址不等
#地址相同 #2,
data=[1,2,3,4]
nums=[]
for i in data:
nums.append(str(i))#存放的是一个字符串,因为字符串得到的是一个新值
print(id(data[0]),id(nums[0]))
#地址不同 #3.
data=["a","b","c"]
nums=[]
for i in data:
nums.append(i)
print(id(data[0]),id(data[0]))
#相同 #4.
v1=[
[1,2,3],[2,3,4]
]
v2=[]
for item in v1:
v2.append(item)
print(id(v1),id(v2))#不同
print(id(v1[0]),id(v2[0]))#相同示例7:(字符串和集合运算)的修改后,不会影响原来的值 而是开辟新空间存储
v1="Gao"
v2=v1
v1.upper()#新开辟一块空间
print(v1,v2)
"Gao"
"Gao" v1={1,2,3}
v2=v1
v1.intersection({2,3})#生成新的集合 开辟新的空间 对原来的集合没没有影响
2.查看内存地址: id()
v1=[1,2,3]
v2=v1
#v2=[1,2,3]
print(id(v1),id(v2))#
3.python小数据池缓存机制:
- 优化功能 某些条件的相同值不会被重新开辟内存空间
- 1.int: -5<=num<=256:内存地址相同
- "Gao"/"ddjdj" ——>相同地址/"f_"*3类型除外
#1.int -5<=num<=256:内存地址相同
v1=1
v2=1
id(v1)==id(v2)#True
2.v1=257
v2=257
print(id(v1),id(v2))#False
2.字符串:"Gao"/"ddjdj" ---->/"f_"*3类型除外
str1="Gao"
str2="Gao"
id(str1)==id(str2)#True
4.易考点 == / is
== 和 is 的区别
== 和 is 的区别
1.==是 值比较
is 是地址比较
(注意考虑小数据池缓存机制)
v1=[1,2,3]
v2=[1,2,3]
print(v1==v2) #True
print(v1 is v2)#False
v1=[1,2,3]
v2=v1
print(v1==v2) #True
print(v1 is v2)#True
v1=[1,2,3]
v2=[1,2,3,4]
print(v1==v2) #False
print(v1 is v2)#False
#小数据池缓存机制
v1=10
v2=10
print(v1==v2) #True
print(v1 is v2)#True
#2.num>256
v1=1000
v2=1000
print(v1==v2) #True
print(v1 is v2)#False
day06 内存地址 小数据池缓存机制的更多相关文章
- day06——小数据池、深浅拷贝、集合
day06 小数据池 小数据池--缓存机制(驻留机制),只是一种规格,不会实际的开辟一个空间 == 判断两边内容是否相等 ***** # a = 10 # b = 10 # print(a == b) ...
- python27期day06:小数据池、深浅拷贝、集合、作业题。
0.pycharm是代码块.黑窗口是小数据池.如下图: 1.驻留机制(长得像的共用一个内存地址)分小数据池缓存机制:后期开发时能明确知道.为什么不能正常使用.把经常用的东西放入规则(黑窗口)里. 数字 ...
- 小数据池 is 和 ==的区别
小数据池 一.小数据池 1)代码块 python程序是由代码块构成的,一个代码块的文本作为pythont程序执行的单元 官方文档: A Python program is constructed fr ...
- python基础知识四 小数据池,深浅拷贝,集合+菜中菜
四.小数据池,深浅拷贝,集合+菜中菜 1小数据池 --缓存机制(驻留机制) '==' 判断两边内容是否相等 'is' 基于内存地址进行判断是否相同 a = 10 b = 10 print(a ...
- 百万年薪python之路 -- 小数据池和代码块
1.小数据池和代码块 # 小数据池 -- 缓存机制(驻留机制) # == 判断两边内容是否相等 # a = 10 # b = 10 # print(a == b) # is 是 # a = 10 # ...
- 6.Python初窥门径(小数据池,集合,深浅拷贝)
Python(小数据池,集合,深浅拷贝) 一.小数据池 什么是小数据池 小数据池就是python中一种提高效率的方式,固定数据类型,使用同一个内存地址 小数据池 is和==的区别 == 判断等号俩边的 ...
- python的代码块缓存机制,小数据池机制。
同一代码块的缓存机制 在python中一个模块,一个函数,一个类,一个文件等都是一个代码块. 机制内容:Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其 ...
- Python二次编码、小数据池之心照神交
二次编码.解码.小数据池: encode(str:编码):参数编码方式,返回字节码. str_1 = "编码" str_2 = str_1.encode("utf-8&q ...
- python基础之小数据池
一,id,is,== 在Python中,id是什么?id是内存地址,比如你利用id()内置函数去查询一个数据的内存地址: name = '太白' print(id(name)) # 158583128 ...
随机推荐
- POI使用记录
POI CellType类型 CellType 类型 值 CELL_TYPE_NUMERIC 数值型 0 CELL_TYPE_STRING 字符串型 1 CELL_TYPE_FORMULA ...
- UVA11468 Substring
思路 AC自动机+概率dp 设f[i][j]表示当前在第i位在AC自动机的第j个节点,满足条件的概率 AC自动机上的一个节点能被转移到当且仅当这个节点不是中止节点且无法通过fail指针跳到任何一个中止 ...
- Bytom Java版本离线签名
比原项目仓库: Github地址:https://github.com/Bytom/bytom Gitee地址:https://gitee.com/BytomBlockchain/bytom tx_s ...
- [原][译][jsbsim]空气动力学模型库讨论JSBSim对比YASim
英文原文:JSBSim_vs_YASim 准确性和现实性飞行动力学模型的准确性和真实性是针对YASim的争论中提出的两个共同点.实际上,如果你给YASim或JSBSim垃圾参数,它们都将返回垃圾空气动 ...
- fcn+caffe+siftflow实验记录
环境搭建: vs2013,编译caffe工程,cuda8.0,cudnn5.1,python2.7. 还需要安装python的一些包.Numpy+mkl scipy matplotlib sci ...
- 中国历史人物传记数据库 CBDB 若干表简介
''' 推荐使用SQLite版本的CBDB数据库 推荐使用SQlite Studio进行数据库的操作 免费,可视化操作,轻量级应用,无需配置,学习扩展性好,非常适合广大历史系学生. ''' 一 人物基 ...
- Loadrunner加密算法脚本与token作为get请求url上的参数处理
1.当字符串被封装好加密时(下例将算法封装在md5中),使用Loadrunner编写脚本,需要进行如下操作: 1)将md5.h文件添加到Extra Files 下,如图(Loadrunne ...
- 2、使用Angular-CLI初始化Angular项目(踩过的深坑!!!)
1.step1:建一个放项目的文件夹,打开cmd,或vs code的终端,找到文件夹根目录 2.step2:初始化脚手架 初始化命令: ng new 项目名称 --skip-install 注意:-- ...
- mysql和mariadb支持insert delayed的问题
分析一个开源项目,往数据库里添加日志,为了避免写入日志信息影响正常业务,日志的插入方式采用了insert delayed的方式. 打印其数据库语句,复制到mysql执行报如下错误: ERROR 161 ...
- .Netcore使用Session
1.使用Session(进程内) 在startup中添加方法 services.AddSession app.UseSession() services.AddDistributedMemoryCa ...