Bootstrap

python面试题7:Python垃圾回收机制(难度--中等)

题目

介绍一下Python的垃圾回收机制?

回答

垃圾回收机制是一个复杂的系统,用于管理不在使用的内存,防止内存泄漏并提高程序的性能,通常由引用计数,标记–清除,分代收集算法来处理循环引用等问题。

1.引用计数

当一个python对象被调用时,他的引用计数就会增加,当对象为空或删除时,它的引用技术就会减小,当为0时,垃圾回收机制就会释放该对象占用的内存,示例如下:

a=[1,2,3] #a对象被调用,引用技术+1=1
b=a #b对象被调用,引用技术+1=2
del a #a对象被删除,引用技术-1=1
del b #b象被删除,引用技术-1=0
#此时被释放内存
print(a)
"""输出:
NameError: name 'a' is not defined,报错,因为该内存已被释放
"""

2.标记–清除

通常分为两个阶段,第一阶段从根对象出发,遍历所有可达对象的”活动对象“并打上标记,第二阶段是清除阶段,释放所有未标记对象的空间。

3.分代收集

对于新对象进行高频率的检查,老对象则采用低频率检查,因而往往新对象更容易成为垃圾。主要目的是为了减少垃圾回收的开销。

;