校招准备系列3

阅读: 评论:0

校招准备系列3

校招准备系列3

关于python的准备有点少,莫怪莫怪

元组、列表和字典的区别?

元组是不可变对象(immutable),列表和字典是可变对象(mutable)。
元组和列表存储一组对象集合,字典存储的是映射关系。

python的内存管理

.htm
.html

引用计数

每个对象都会维护一个指向该对象的引用计数。引用计数为0的对象会被立即回收。引用计数的缺点是无法处理循环引用,所以有另外2中机制辅助垃圾回收。

标记-清除机制

为引用计数维护一个副本,将环形引用上的对象的引用计数减少1,得到root object集合(该集合中的对象是不能被回收的),其余的分到unreachable(死亡组)。然后二审,到unreachable组中寻找被root object集合中对象引用的对象,移动到root object集合中。
最后,将unreachable集合中的对象清除掉。

分代回收(垃圾回收器会更频繁的处理新对象young)

一定比例的内存块的生存周期都比较短,通常是几百万条机器指令的时间,而剩下的内存块,起生存周期比较长,甚至会从程序开始一直持续到程序结束。将系统中的所有内存块根据其存活时间划分为不同的集合,每一个集合就成为一个“代generation”,垃圾收集的频率随着“代”的存活时间的增大而减小。也就是说,活得越长的对象,就越不可能是垃圾,就应该减少对它的垃圾收集频率。那么如何来衡量这个存活时间:通常是利用几次垃圾收集动作来衡量,如果一个对象经过的垃圾收集次数越多(而仍没有被回收),可以得出:该对象存活时间就越长。
在Python中,总共有3“代”,0,1,2;

GC的时机

程序结束,内存使用达到阈值,主动调用GC

内存池机制

将不用的内存放到内存池而不是返回给操作系统。
Python中所有小于256个字节的对象都使用pymalloc实现的分配器,而大的对象则使用系统的 malloc。

本文发布于:2024-01-31 08:31:36,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170666109727174.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:系列
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23