python垃圾回收&缓存机制

2021/9/27 17:10:59

本文主要是介绍python垃圾回收&缓存机制,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

1.垃圾回收机制?

    计数器为主,标记清楚和分代回收为辅;

    1.1底层结构

      所有的对象都会放在refchain的双向循环链表中。

        每一个对象都等于结构体
        typedef obj{
          上一个指针
          下一个指针
          引用个数
          数值类型
          值
         }

    1.2计数器

      创建的时候计数器为1

      被引用,则计数器加一

      删除引用,则计数器减一

      bug:循环引用会有问题?

          a = []

          b = []

          a.append(b)

          b.append(a)

          del a

          del b

    1.3标记清除

      会把有循环引用的对象放在另外一个双向循环链表中,

      某种条件会触发,去扫描,如果存在循环引用,则计数器-1

      bug:

        什么时候扫描

        扫描代价太大

    1.4分代回收

      将标记清楚的链表  变成三个链表

      0代:对象有700个扫描一次

      1代:0代扫描10次则触发

      2代:1代扫描10次则触发

 

2缓存机制:

  2.1缓存池(整形,字符):【-5,257】都是常用的不会创建对象,都会在小数据池

  2.2free_list(字典,列表,元组,字符串)(有个数限制):当对象成为垃圾的时候不会被清除,而会放在free_list里面,等下次用的时候,

    就不需要重新开辟空间了;

 



这篇关于python垃圾回收&缓存机制的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程