笔记中代码均可运行在Jupyter NoteBook下(实际上Jupyter-lab使用体验也很棒)。
建议不要光看,要多动手敲代码。眼过千遭,不如手读一遍。
相关笔记的jupiter运行代码已经上传,请在资源中自行下载。
垃圾回收
参考网址:https://www.cnblogs.com/jin-xin/articles/9439483.html
概括:
同一代码块下:缓存机制
不同代码块:小数据池
代码块
一个模块、一个函数、一个类、一个文件都是一个代码块。
在交互式命令行下,一个命令就是一个代码块。
代码块的缓存机制
Python在执行同一个代码块的初始化对象的命令时,
会检查是否其值是否已经存在,如果存在,会将其重用。
换句话说:
执行同一个代码块时,遇到初始化对象的命令时,
他会将初始化的这个变量与值存储在一个字典中,
在遇到新的变量时,会先在字典中查询记录,
如果有同样的记录那么它会重复使用这个字典中的之前的这个值。
满足缓存机制则他们在内存中只存在一个,即:id相同。
代码块的缓存机制的适用范围: int(float),str,bool。
int(float):任何数字在同一代码块下都会复用。
bool:True和False在字典中会以1,0方式存在,并且复用。
str:几乎所有的字符串都会符合缓存机制
1,非乘法得到的字符串都满足代码块的缓存机制
2,乘法得到的字符串分两种情况:
2.1 乘数为1时,任何字符串满足代码块的缓存机制:
2.2 乘数>=2时:仅含大小写字母,数字,下划线,
总长度<=20,满足代码块的缓存机制
优点:
能够提高一些字符串,整数处理人物在时间和空间上的性能;
需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁创建和销毁,提升效率,节约内存。
'''jupyter这里运行存在问题,以注释为主'''
# 字符串缓存机制 例子
# 非乘法得到的字符串
def unMult():
s1 = 'string'
s2 = 'string'
print('非乘法得到的字符串')
print('*'*30)
print('s1和s2地址比较:',id(s1) == id(s2)) # True
print('*'*30)
# 乘数为1得到的字符串
def