代码块
什么是代码块
在python中代码块指的是
一个模块,一个函数,一个类,一个文件等都是代码块
而在用户交互里面,就是cmd中进入python解释器例,每一行代码就是一个代码块.
is
is 是比较的两边的内存地址是否相等
==
比较俩边的数值是否相等
id
指内存地址,利用id()内置函数去查询一个数据的内存地址
小数据池(驻留机制,小整数缓存机制)
是python对内存做的一个优化,对一些常用的数字(整数-5~256),一定规律的字符串提前创建一个小数据池(容器),
优点:节省内存,在内存级别提高性能与效率,常用的字符串可以直接从小数据池中提用
缺点:在“池”中创建或插入字符串,整数时,会“相对”花费更多的时间
int:
在小数据池中保存的有(-5~256)之间的整数,即之间从小数据池中调用
str:
1.对于字符串是ASCII码中的,默认采用小数据池(驻留机制)
注意:字符串的内容不包括中文,字符串中含有特殊字符的话长度(字符串的长度)只能是1才是True,
2.对于乘法,如果a = "afhjdhsaflh***" b = a *1 print(a is b) 输出都是True,即都默认采用驻留机制
如果是乘于2以上的 即a = "aslfj"*4 b = "aslfj"*4 总长度必须在20以内才是默认采用驻留机制
指定驻留
from sys import intern a = intern('hello!@'*20) b = intern('hello!@'*20) print(a is b) #指定驻留是你可以指定任意的字符串加入到小数据池中,让其只在内存中创建一个对象,多个变量都是指向这一个字符串。
bool
布尔值始终保存在小数据池内
编码升级
不同编码直接不可以直接识别,都是进过转化才可以识别的
网络传输和存储:由于Unicode太占用内存,所以必须以非Unicode的编码进行网络传输或者存储
在大环境python3x中
str:字符串的编码是Unicode
其余都是utf-8
所以引入了bytes的数据类型概念
ytes类型和字符串类型是类似关系,字符串类型的内置函数在bytes类型都可以使用。
而区别是bytes类型没办法以b'中文字符串'的类型存储中文数据,只有字符串可以,并且bytes类型的内存编码方式不是Unicode,所以当字符串需要进行网络传输和存储时必须进行编码,就是把Unicode->其他编码方式进行操作。
编码及解码:
str->bytes encode 编码
bytes->str decode 解码