Python(小数据池,集合,深浅拷贝)

一.小数据池

  1. 什么是小数据池

    小数据池就是python中一种提高效率的方式,固定数据类型,使用同一个内存地址

  2. 小数据池 is和==的区别

    == 判断等号俩边的值是否相同

    is 判断两个内存地址是否相同

  3. 小数据池和代码块的关系

    注意 : 先执行代码块后执行小数据池

    ​ 小数据池 : 支持str,int,bool

    ​ 数字范围 : -5~256

    ​ 字符串 : 1.在做乘法的时候总长度不能超过20

    ​ 2.自定义的字符串,长度不限制,字符串必须(字母,数字,下划线)组成

    ​ 3.特殊字符(中文除外)定义一个时候,进行驻留

    ​ 4.字符串1,其实就是赋值

    ​ 代码块 : 一个文件,一个模块,一个函数,一个类

    ​ 数字 : 全部驻留

    ​ 字符串 : 1.字符串做乘法的时候总长度不能超过20

    ​ 2.自定义的都驻留

    ​ 3.字符串*1,其实就是赋值

    ​ 4.python3.7 乘法的时候总长度不能超过4096

二.集合

  1. 集合介绍

    什么是集合 : set就是dict类型的数据但是不保存value,只保存key.set也用{}表示

    关键字 : set

    集合特点 : 集合是可变的,集合内的元素是无序的,元素不可变并且唯一,天然去重
  2. 集合操作
    • 增 :

      set.update()迭代添加

      set.add()集合添加
    • 删 :

      set.pop()随即删除

      set.remove()制定元素删除

      set.clear()清空元素

      del s 删除整个集合
    • 改 : 删除后添加
    • 查 : for查找
    • 其他操作 :

      print(s1-s2)差集

      print(s1|s2)并集

      print(s1&s2)交集

      print(s1^s2)反交集

      print(s1>s2)父集

      print(s1<s2)子集
    • 冻结集合 : 把可变的转换成不可变的

      frozenser()
s = frozenset(["武当","少林","峨眉","丐帮"])
dic = {s:'123'} # 冻结s后就可以正常使用了
print(dic)

三.深浅拷贝

  1. 先了解以下什么是赋值

    ​ 对于list, set, dict来说, 直接赋值,其实是把内存地址交给变量,并不是复制一份内容,所以lst1的内存指向和lst2是一样的,lst1改变了,lst2也同样发生了改变.

    lst1 = ["武当","少林","峨眉","丐帮"]
    lst2 = lst1
    print(lst1)
    print(lst2)
    lst1.append("师太")
    print(lst1) # ["武当","少林","峨眉","丐帮","师太"]
    print(lst2) # ["武当","少林","峨眉","丐帮","师太"]
    ---------------------------------
    dic1 = {"age":104,"name":"张三丰"}
    dic2 = dic1
    print(dic1) # {"age":104,"name":"张三丰"}
    print(dic2) # {"age":104,"name":"张三丰"}
    dic1['name']="灭绝"
    print(dic1) # {"age":104,"name":"灭绝"}
    print(dic2) # {"age":104,"name":"灭绝"}
  2. 浅拷贝

    ​ 浅拷贝,只会拷贝第一层,二层的内容不会拷贝,所以被称为浅拷贝

    lst1 = ["张三丰","方丈","乞丐"]
    lst2 = lst1.copy()
    lst1.append("灭绝")
    print(lst1)
    print(lst2)
    print(id(lst1), id(lst2))
    # 两个lst完全不一样,内存地址和内容也不一样,但是实现了内存的拷贝
    ---------------------------------
    lst1 = ["张三丰","乞丐","方丈",["祥龙","伏虎","罗汉"]]
    lst2 = lst1.copy()
    lst1[3].append("灭绝")
    print(lst1) # ["张三丰","乞丐","方丈",["祥龙","伏虎","罗汉","灭绝"]]
    print(lst2) # ["张三丰","乞丐","方丈",["祥龙","伏虎","罗汉","灭绝"]]
    print(id(lst1[3]),id(lst2[3])) # id相同
    # 只会拷贝第一层,二层的内容不会拷贝,因此第二层元素发生改变则都会改变.
  3. 深拷贝

    ​ 深度拷贝,把元素内部的元素完全进行拷贝复制,一个改变另一个不会跟着改变,当使用深拷贝时需要调用import copy.

    import copy
    lst1 = ["张三丰","乞丐","方丈",["祥龙","伏虎","罗汉"]]
    lst2 = copy.deepcopy(lst1)
    lst1[3].append("灭绝")
    print(lst1) # ["张三丰","乞丐","方丈",["祥龙","伏虎","罗汉","灭绝"]]
    print(lst2) # ["张三丰","乞丐","方丈",["祥龙","伏虎","罗汉"]]
    print(id(lst1[3]), id(lst2[3])) # id不同
    # 元素内部的元素完全进行拷贝复制,一个改变另一个不会跟着改变

6.Python初窥门径(小数据池,集合,深浅拷贝)的更多相关文章

  1. Python基础知识(六)------小数据池,集合,深浅拷贝

    Python基础知识(六)------小数据池,集合,深浅拷贝 一丶小数据池 什么是小数据池: ​ 小数据池就是python中一种提高效率的方式,固定数据类型使用同一个内存地址 代码块 : ​ 一个文 ...

  2. python的小数据池和深浅拷贝

    小数据池 一种数据缓存机制,也称驻留机制 在同一代码块,相同的值不会开辟新的内存 特殊字符除外 小数据池只针对:在控制台时! 数字 :-5到256间的整数会被缓存 布尔值:都会缓存8 字符串 小于等于 ...

  3. python基础知识四 小数据池,深浅拷贝,集合+菜中菜

    四.小数据池,深浅拷贝,集合+菜中菜 1小数据池 --缓存机制(驻留机制) ​ '==' 判断两边内容是否相等 ​ 'is' 基于内存地址进行判断是否相同 a = 10 b = 10 print(a ...

  4. Python 入门之代码块、小数据池 与 深浅拷贝

    Python 入门之代码块.小数据池 与 深浅拷贝 1.代码块 (1)一个py文件,一个函数,一个模块,终端中的每一行都是代码块 (代码块是防止我们频繁的开空间降低效率设计的,当我们定一个变量需要开辟 ...

  5. python27期day06:小数据池、深浅拷贝、集合、作业题。

    0.pycharm是代码块.黑窗口是小数据池.如下图: 1.驻留机制(长得像的共用一个内存地址)分小数据池缓存机制:后期开发时能明确知道.为什么不能正常使用.把经常用的东西放入规则(黑窗口)里. 数字 ...

  6. day06——小数据池、深浅拷贝、集合

    day06 小数据池 小数据池--缓存机制(驻留机制),只是一种规格,不会实际的开辟一个空间 == 判断两边内容是否相等 ***** # a = 10 # b = 10 # print(a == b) ...

  7. day4-python基础-小数据池以及深浅copy浅讲

    今天的目录是 1.小数据池 2.深浅copy 正文开始 1.小数据池 在说明今天的内容前,先说明一个在今天重复用到的一个知识点 ###比较’=’俩边的数据是否完全相同,以及判断一个对象的内存地址是否完 ...

  8. python之小数据池

    代码块 Python 程序 是由代码块构造的.块是一个python程序的文本,它是作为一个执行单元的. 代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块. 而作为交互方式输入的每个命令都是 ...

  9. python的小数据池

    一.什么是小数据池? 小数据池是一种缓存机制,也被称为驻留机制.各种编程语言中都有类似的东西(常量池.小数据池都是指得同一个内容). python自动将-5~256的整数.有一定规则的字符串.都放在一 ...

随机推荐

  1. jetty使用jndi数据源

    之前将项目正常的数据源统一切换成jndi访问的形式(是将c3p0以mbean形式安装到jboss做的数据连接池), 本地测试用的jetty服务器,为了统一数据库访问部分,我也查看文档找到了jetty提 ...

  2. BZOJ 1206 [HNOI2005]虚拟内存:模拟

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1206 题意: 内存大小为n(外存无限大),共有m次访问,每一次访问的信息编号为p. 对于每 ...

  3. html5--1.3 元素的概念与3个常用标签

    html5--1.3 元素的概念与3个常用标签 学习要点 1.元素的概念 2.3个常用的标签 HTML 元素指的是从开始标签到结束标签的所有代码. 开始标签 元素内容 结束标签 <h1> ...

  4. Linux下的磁盘缓存

    转自:http://blog.csdn.net/cywosp/article/details/21126161 前段时间在开发一个使用SSD做缓存的系统,在高速写入数据时会出现大量的磁盘缓存.太多的磁 ...

  5. UOJ_14_【UER #1】DZY Loves Graph_并查集

    UOJ_14_[UER #1]DZY Loves Graph_并查集 题面:http://uoj.ac/problem/14 考虑只有前两个操作怎么做. 每次删除一定是从后往前删,并且被删的边如果不是 ...

  6. window下的hosts

    存放在windows系统目录中的\system32\drivers\etc下面. hosts文件是用来记录主机ip地址和主机名的对应关系,建立后就可以用主机名来访问主机,而不必记ip地址了.hosts ...

  7. CentOS7的网络配置

    1.DNS配置 新安装的虚拟机,ping 内网IP可以,但是ping 外网域名却失败,告知“Name or service not known”. 原来是因为需要在/etc/sysconfig/net ...

  8. HDU3974(dfs+线段树)

    Assign the task Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...

  9. js修改页面动态添加input框显示与按钮可编辑

    1. <%@ page language="java" contentType="text/html;charset=UTF-8"%> <%@ ...

  10. [hdu3586]Information Disturbing树形dp+二分

    题意:给出一棵带权无向树,以及给定节点1,总约束为$m$,找出切断与所有叶子节点联系每条边所需要的最小价值约束. 解题关键:二分答案,转化为判定性问题,然后用树形dp验证答案即可. dp数组需要开到l ...