一、小数据池

  1、代码块
  python程序是由代码块构成的。一个代码块的文本作为python程序执行的单元。代码块: 一个模块, 一个函数, 一个类, 甚至每一个command命令都是一个代码块. 一个文件也是一个代码块, eval()和exec()执行的时候也是一个代码块。
 
  2、小数据池:一种数据缓存机制,也被成为驻留机制,它只针对整数、字符串、布尔值(不可变)其他数据类型不存在驻留机制。
  在python中对-5 ~256之间的整数会被驻留在内存中,将一定规则的字符串缓存,在使用的时候,内存中只会创建一个该数据的对象,保存在小数据池中,当使用的时候直接从小数据池中获取对象的内存引用,而不需要创建一个新的数据,节省内存区域。
  优点:能够提高一些字符串、整数的处理速度,省略创建对象的过程
  缺点:在池中创建或者插入新内容会花费更多时间
 
  3、针对数字、字符串
    (1)数字:-5~256是会被加到小数据池中的,每次使用都是同一对象
    (2)字符串:
    <1>如果字符串的长度是0 或 1,都会默认进行缓存
    <2>字符串长度大于1,但字符串中只含字母、数字、下划线时才会缓存
    <3>用乘法得到的字符串,乘数为1,只含字母、数字、下划线时才会缓存,如果包含其他字符,而长度<=1也会被驻存。乘数大于 1,只含字母、数字、下划                                      线时才会缓存,但字符串长度<=20
    <4>指定驻留,通过导入os模块

 from sys import intern()
a = intert('#$%^*fjewio')
b = intert('#$%^*fjewio')

  在代码块内的缓存机制是不一样的. 在执行同一个代码块的初始化对象的命令时, 会检查是否其值是否已经存在, 如果存在, 会将其重用. 换句话说: 执行同一个代码块时, 遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中, 在遇到新的变量时, 会先在字典中查询记录, 如果有同样的记录那么它会重复使用这个字典中的之前的这个值. 所以在你给出的例子中, 文件执行时(同一个代码块) 会把a, b两个变量指向同一个对象.如果是不同的代码块, 他就会看这个两个变量是否是满足小数据池的数据, 如果是满足小数据池的数据则会指向同一个地址. 所以: a, b的赋值语句分别被当作两个代码块执行, 但是他们不满足小数据池的数据所以会得到两个不同的对象, 因此is判断返回False.

二、is 和 ==的区别

  1、id() #通过id()可以查看一个变量表示的值在内存中的地址。
  2、is :判断左右两端内容的内存地址是否一致,如果返回True则两变量使用的是同一对象
  3、== :判断左右两端的值是否相等,内容是不是一样的
  内存地址相同,那么值一定是相等的,如果值相等,则不一定是同一个对象。

三、编码、解码

  1、回顾
  ASCII码 只有大小写字母、数字、一些特殊字符,没有中文,8 bit(1B)
  GBK:中文编码里面包含ASCII,16bit(2B)
  Unicode:万国码,32bit(4B)
  UTF-8:可变长万国码,是Unicode的一种实现,最小字符占8位,英文8bit(1B)、欧洲 16bit(2B)、中文24bit(3字节)
  除了ascii码以外,其他信息不能直接转换。
 
  2、Unicode和utf-8
  在python3的内存中,在程序运行阶段,使用的是Unicode编码,因为Unicode是万国码,什么内容都可以进行显示,那么在数据传输和储存的时候由于Unicode比较浪费空间和资源,需要把Unicode转存成utf-8或者GBK进行存储,在python中科院把文字信息进行编码,编码之后的内容就可以进行传输了,编码之后的数据是bytes类型数据
  bytes的表现形式:1.英文 b'alex' 2.中文 b'\xe4\xb8\xad'
 
  3、编码解码
  字符串在传输时转换成bytes =>encode(字符集)来完成

 s = 'alex'
print(s.encode('utf-8')) # 将字符串编码成UTF-8
print(s.encode('GBK')) #将字符串编码成GBK
结果:
b'alex'
b'alex' s = '中'
print(s.encode('utf-8')) # 将字符串编码成UTF-8
print(s.encode('GBK')) #将字符串编码成GBK
结果:
b'\xe4\xb8\xad'
b'\xd6\xd0'

  注意:英文编码之后的结果和源字符串一致,中文编码之后的结果根据编码的不同,编码结果也不同,我们能看到,一个中文的UTF-8是3字节,一个GBK的中文编码是2字节。编码之后的数据类型是bytes,在网络传输和存储的时候我们python是保存和存储的bytes类型,那么在对方接收的时候,也是接收的是bytes类型的数据,我们可以使用decode()来进行解码操作,把bytes类型的数据还原回字符串

 s = "我叫李嘉诚"
print(s.encode("utf-8")) #
b'\xe6\x88\x91\xe5\x8f\xab\xe6\x9d\x8e\xe5\x98\x89\xe8\xaf\x9a'
print(b'\xe6\x88\x91\xe5\x8f\xab\xe6\x9d\x8e\xe5\x98\x89\xe8\xaf\x9a'.decode("utf-8")) # 解码

  编码和解码的时候都需要指定编码格式

 s = "我是文字"
bs = s.encode("GBK") # 我们这样可以获取到GBK的文字
# 把GBK转换成UTF-8
# 首先要把GBK转换成unicode. 也就是需要解码
s = bs.decode("GBK") # 解码
# 然后需要进行重新编码成UTF-8
bss = s.encode("UTF-8") # 重新编码
print(bss)

06_python_小数据池/ is == /编码的更多相关文章

  1. python学习笔记:第6天 小数据池和编码转换

    目录 1. id 和 == 2. 小数据池 3. 编码和解码 1. id 和 == id:id是一个内置的函数,可以查看变量存放的内存地址(实际上不是真正的物理地址,这里暂时这样理解),用于判断是变量 ...

  2. python 浅谈小数据池和编码

    ⼀. ⼩数据池 在说⼩数据池之前. 我们先看⼀个概念. 什么是代码块: 根据提示我们从官⽅⽂档找到了这样的说法: A Python program is constructed from code b ...

  3. python:id与小数据池与编码

    一.id与小数据池 id:查的是内存地址 a = 100 b = 100 print(a == b)#比较的数值 print(a is b)#比较的是id print(id(a),id(b))#id相 ...

  4. 《Python》 代码块、小数据池和编码转换

    一.代码块 Python程序是由代码块构造的.块是一个python程序的文本,他是作为一个单元执行的. 什么是代码块:一个py文件,一个函数,一个文件,一个类都是一个代码块. 作为交互方式输入的每一行 ...

  5. python基础4(小数据池,编码,深浅拷贝)

    1.==与is == 比较值是否相等 is比较内存地址是否相同 2.小数据池 为了节省内存,当数据在一个范围里的时候,两个值相同的变量指向的是小数据池里的同一个地址 数字范围:-5 ~ 256 num ...

  6. day06 小数据池和编码

    一. 上次课内容回顾字典:由{}括起来. 每个元素用逗号隔开, key:value的形式存储数据key: 不可变的. 可哈希的.增删改查:1. 增加: 直接用新key来赋值. dict[key] = ...

  7. 6,id 小数据池,编码and解码。

    asscii :8位(数字,英文,特殊字符)表示一个字符. A:0000 0001 unicode :(万国码)初期:16位,两个字节,表示两个字符. A:0000 0001 0000 0001 中: ...

  8. python小整数与str数据池,编码关系

    1.小数据池:数字,字符串 数字的范围-5 ---256 字符串:1,不能有特殊字符 2,s*20 还是一个地址,s*21以后都是两个地址 2.编码关系:ascii A : 00000010 8位 一 ...

  9. id,is的用法,小数据池的概念及编码知识进阶

    一:id 查询内存地址 name = 'alex' print(id(name)) li = [1,2,3] print(id(li)) 二:is  判断的是内存地址 name1 = 'alex@' ...

随机推荐

  1. 【Java】JavaWeb 登录检查及界面跳转

    场景 一般javaweb网站都有用户登录,而有一些操作必须用户登录才能进行,常见流程:用户请求-->后台判断是否登录-->没登录跳转到登录界面,登录用户正常操作 解决思路 在用过滤器过滤请 ...

  2. C# 使用 HttpPost 请求调用 WebService

    之前调用 WebService 都是直接添加服务引用,然后调用 WebService 方法的,最近发现还可以使用 Http 请求调用 WebService.这里还想说一句,还是 web api 的调用 ...

  3. MZOJ 1344 工作依赖

    这道题并不是很难,关键在于读入; 其余只需一个遍历;(考的时候傻逼兮兮的没写出来) 另外,学到了一个 isdigit()用来判断是否是0-9的数字; #include <bits/stdc++. ...

  4. 2018.12.19 atcoder Iroha and a Grid(组合数学)

    传送门 组合数学好题. 给你一个hhh行www列的网格,其中左下角aaa行bbb列不能走,问从左上角走到右下角有多少种走法(每次只能向右或者向下) 我们考虑分步计数. 我们一共能走的区域是总网格区域去 ...

  5. 2018.06.27 POJ3281 Dining(最大流)

    Dining Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 21578 Accepted: 9545 Description C ...

  6. SQL错误

    一.mybatis框架XML错误 1.ORA-00918: 未明确定义列:SQL语句中列明重复,或者定义不明确(关联查询时两张表都有要区分开列明) 2.无效的列类型: 1111  :a.传入数据漏传一 ...

  7. Codeforces Round #514 (Div. 2) E. Split the Tree(倍增+贪心)

    https://codeforces.com/contest/1059/problem/E 题意 给出一棵树,每个点都有一个权值,要求你找出最少条链,保证每个点都属于一条链,而且每条链不超过L个点 和 ...

  8. python模块:shutil

    """Utility functions for copying and archiving files and directory trees. XXX The fun ...

  9. 链家web前端面试

    共有三轮面试,每个面试官的第一个问题都是:介绍一个你觉着比较出彩的项目 第一轮面试: 因为公司项目没什么亮点,很传统的pc端,美女面试官就说让讲一下我用react的私人项目; 问了很多都是关于reac ...

  10. js动态删除某一行,内容超出单元格后超出的部分用省略号代替

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <s ...