python, six day

一、代码块

什么是代码块?

  

Python程序是由代码块构造的。块是一个python程序的文本,他是作为一个单元执行的。

代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块。

而作为交互方式输入的每个命令都是一个代码块。

def func():
print(333)
class A:
name = 'alex'

交互模式下,每一行是一个代码块。
>>> i1 = 1000 可以理解为这一行在一个文件中。
>>> i2 = 1000 可以理解为这一行在另一个文件中。

二、id is ==

在内存中id都是唯一的,如果两个变量指向的值的id相同,就证明他们在内存中是同一个。
is 判断的是两个变量的id值是否相同。
如果is是True, == 一定是True。

三、小数据池

小数据池,也称为小整数缓存机制,或者称为驻留机制

小数据池的应用的数据类型: 整数,字符串,bool值

小数据池,python对内存做的一个优化:
他将 -5 ~256 的整数,以及一定规则的字符串,提前在内存中创建了池,容器,
容器里固定的放了这些数。
为什么这么做???
1,节省内存。
2,提高性能与效率。
i1 = 100
i2 = 100

一定规则的字符串?

代码块:
python在同一个代码块中的变量,初始化对象的命令时,它会将变量与值的对应关系放到一个字典中,
如果下面的代码在遇到初始化对象的命令,他会先从字典中寻找,如果存在相同的值,他会复用,指向的都是同一个内存地址。
dic = {'name': hello@的内存地址,}
python对于不同的代码块:初始化对象的命令时,他会从小数据池中寻找。

优点:能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘池’里拿来用,避免频繁的创建和销毁,提升效率,节约内存。

缺点:在‘池’中创建或插入字符串,整数时,会花费更多的时间。

四、编码

s1 = '晓'
b1 = s1.encode('utf-8')
b2 = s1.encode('gbk')
print(b1)
print(b2)

str --- > bytes encode 编码
s1 = 'alex'
s2 = '晓'
b1 = s1.encode('utf-8')
print(b1)
b2 = s2.encode('gbk')
print(b2)

bytes ---> str decode 解码
b1 = b'\xcc\xab\xb0\xd7'  #gbk 的bytes
s2 = b1.decode('gbk')
print(s2)

猜你喜欢

转载自www.cnblogs.com/study-learning/p/9452807.html
six