小数据池、集合和深浅拷贝的个人理解
小数据池----缓存机制(驻留机制)
==:判断两边内容是否相等
is :判断基于内存地址进行判断
小数据池的数字范围-5~256
代码块:一个文件、一个函数、一个模块,终端中每一行是一个代码块
代码块支持的数据类型:数字:在同一个代码块中。只要内容相同就采用相同的内存地址(-6往后都不是)在做乘法的时候范围-5~256。数字在做乘法的时候不能使用浮点数(这些都是在cham中的结果)
字符串:在同一代码块中,只要内容相同就采用相同的内存地址。乘法的时候总长度不能超过20。乘法的时候中文、特殊符号乘以1或0
布尔值:在同一代码块中。只要内容相同就采用相同的内存值
小数据池:数字:范围是-5~256
字符串:在同一小数据池中,只要内容相同就采用相同的内存地址。乘法的时候总长度不能超过20。乘法的时候中文 、特殊符号乘以0。字母,数字长度任意符合驻留机制。
布尔值:在同一小数据池中,只要内容相同就采用相同的内存地址
小数据池的验证法,必须脱离代码块才能进行验证。执行顺序:先执行代码块的规则,在执行小数据的规则--(驻留机制)
驻留机制作用:节省内存空间,提升效率(减少了开辟空间和销毁空间的时间)
集合
python中数据类型之一
集合----set:关键字
定义方式:s={1,2,3,4,}
集合就是一个没有值的字典。
无序,可变。集合自动去重。
增:s={}#字典
s1=set({})#空集合
s1.add()#添加
s1.update()#迭代添加
set()#迭代添加
删:s1.remove(元素)#删除
s1.clear()#清空
s1.pop()#随意删除
改:先删后加
查:for循环
其他操作:
s2={1,23,9,4,5,7}
s3={1,2,3,4,5}
差集-#print(s2-s3)
交集&#print(s2&s3)
并集|#print(s2|s3)
反交集^#print(s2^s3)
子集、父集(超集)
冻结集合:不可变了。可以当成字典的键。
frozenset({1,23,4,5})
深浅拷贝 复制
浅拷贝
面试必问:赋值,浅拷贝,深拷贝
以后尽量避免
lst.copy():浅拷贝#lst[:]
浅拷贝就是在源基础上就是开个框架,把公用的数据进行同样使用。但是浅拷贝和元数据的框架的是不一样的。
浅拷贝和源数据相比,如果源数据中元素进行变动,则浅拷贝的数值不进行变动。如果源数据中元素内进行添加或变动,浅拷贝的元素也会和源数据一起进行添加或变动。如果只是单独的元素直接被赋值,另外一方则不会变动。
赋值:将多个变量指向一个同一个内存地址就是赋值。
“=”是修改,.appedn是添加。可变数据类型能够修改和添加,不可变数据类型智能修改。
深拷贝
import copy #导入copy模块
a=[1,2,3,[4,5],6]
b=copy.deepcopy(a)