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里面,等下次用的时候,

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

 

posted @ 2021-09-27 16:26    阅读(37)  评论(0编辑  收藏  举报