校招准备系列3-Python

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

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

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

python的内存管理

https://www.jb51.net/article/52229.htm
https://www.cnblogs.com/pinganzi/p/6646742.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。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值