python的gc(Garbage collection)

小整数池[-5,257)共用对象,长驻内存

python的intern机制  共用同一段内存(单个单词,不可修改,默认开启intern机制)

python的gc(Garbage collection)_第1张图片

Java c#都有垃圾回收机制

引用计数简单,但维护引用消耗资源,出现循环引用的时候出现无法回收对象的风险

 

python(一旦没有引用立刻清除)和ruby(先申请大量的内存,全部用完后再清除内存,标记-清除)

python以引用计数为主,隔代回收为主

python的gc(Garbage collection)_第2张图片

当gc触发的时候,0代并不是所有的都减去1  而是先判断是否有相互引用,如果有才把相互引用的部分减1  把没有相互引用的部分放到下一代

gc.get_threshold()  ---->(700,10,10)  表示(残留对象大于700清理0代,清理了10次0代清理1代,清理了10次1代清理2代)

引用计数加1的情况:1对象被创建  2  对象被引用  3  对象被作为参数传入函数   4对象作为一个元素存储在容器

引用计数减1的情况: 相反即可

 

sys.getrefcount(a)  得到a的引用数量     gc.collect()显示执行垃圾回收   gc.garbge显示刚被处理的对象

 

内建属性:

python的gc(Garbage collection)_第3张图片

 

 

 

你可能感兴趣的:(python的gc(Garbage collection))