1.gc机制(garbage collection)
引用计数机制为主,标记清除和隔代回收为辅。python里每一个东西都是对象,它们的核心就是一个结构体:PyObject
typedef struct_object {
int ob_refcnt;
struct_typeobject *ob_type;
} PyObject;
PyObject是每个对象必有的内容,其中ob_refcnt就是做为引用计数。当一个对象有新的引用时,它的ob_refcnt就会增加,当引用它的对象被删除,它的ob_refcnt就会减少.当引用计数为0时,该对象生命就结束了。
引用计数机制的优缺点
- 优点:简单:实时性:一旦没有引用,内存就直接释放了。不用像其他机制等到特定时机。实时性还带来一个好处:处理回收内存的时间分摊到了平时。
- 维护引用计数消耗资源.循环引用,解决不了
list1与list2相互引用,如果不存在其他对象对它们的引用,list1与list2的引用计数也仍然为1,所占用的内存永远无法被回收,这将是致命的。 对于如今的强大硬件,缺点1尚可接受,但是循环引用导致内存泄露,注定python还将引入新的回收机制。(标记清除和分代收集)
GC系统所承担的工作远比"垃圾回收"多得多。实际上,它们负责三个重要任务。它们是
- 为新生成的对象分配内存
- 识别那些垃圾对象
- 从垃圾对象那回收内存。
2.ruby和python垃圾回收机制对比
- ruby是回收时是先进行标记,然后等到内存不够用的时候集体清除,
- python的话会只要产生一个垃圾就进行标记清除,python每次都这样,会比较浪费资源.