python的垃圾回收机制 继承的顺序C3算法

本文深入探讨了Python的垃圾回收机制,包括引用计数、标记清除和分代回收策略,以及如何解决循环引用问题。同时,解析了Python中MRO(Method Resolution Order)算法的工作原理,介绍其用于确定类继承顺序的方法。

Python垃圾回收
    -- 引用计数
        -- Python为每个对象维护一个引用计数
        -- 当引用计数为0的 代表这个对象为垃圾
    -- 标记清除
        -- 解决孤立的循环引用
        -- 标记根节点和可达对象
        -- 不可达视为垃圾
    -- 分代回收
        -- 解决标记清除的效率问题
        -- 0代 1代 2代
        -- 阈值 (700,10,10)
        -- 当调用c的接口开辟内存和销毁内存的差值为700的时候出发0代回收
        -- 0代触发10次 触发1代回收
        -- 1代触发10次 触发2代回收
        -- 每次回收结束 没有被回收的对象放入下一代
参考:http://www.cnblogs.com/Xjng/p/5128269.html


PythonMRO c3算法
    -- 找到类的mro的继承顺序
    -- 第一步 找到所有父类的mro
    -- 第二步 用这些父类的mro 跟所有的父类进行归并
        -- 取每个表表头 并且其他表去掉表头的部分不能含有我们要取的那个表头
        -- 如果不满走就去取第二个表头

参考:http://python.jobbole.com/85685/

转载于:https://www.cnblogs.com/Mr-Murray/p/9707018.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值