在python中使用gc.collect()清除内存对缓存数据的queue队列是否有影响

使用gc.collect()清除内存时,不会影响多线程中正在使用的queue队列,除非对象的引用计数器归零。队列对象是否被回收取决于其引用情况,而非队列内是否有数据。
摘要由CSDN通过智能技术生成

CSDN问答频道为您的问题找到合适的答案,帮助用户获得可信赖的优质解答

原问题来自于CSDN问答频道,该问题更多解决方案见:https://ask.csdn.net/questions/7426599

问题描述:

由于使用del语句删除列表中的数据只是删除变量的引用,并没有达到清除数据的作用,所以想用gc.collect清除数据所占的内存。于是想问问使用gc.collect时会对多线程中用来缓存数据的queue队列有影响吗?


解决方案——来自答主@天元浪子

如果没有交叉或循环引用,对象的del方法就会释放内存,否则就需要调用gc来手工清理。不管是哪一种方式,如果对象的引用计数器没有归零,该对象就不会被清理,线程间交换数据的队列也是如此,所以题主不必担心gc会清理掉还在使用中的队列。

1、del list[0]是否会立即回收list[0]占用的内存,取决于list[0]是否被其他对应引用,如果有被引用,gc.collect()也无法收回。用下面的代码可以验证。 

>>> import gc
>>> a = [1, {'x'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值