文章目录

  • 前言
  • 一、python内存泄漏原因
  • 二、循环破解
  • 三、使用requests中的内存泄漏问题
  • 四、opencv内存泄漏(未解决过)



前言

python在正常使用情况下,不会出现内存泄漏。但是遇到request、opencv模块时就经常被爆出内存泄漏。本文主要讲述requests下出现内存泄漏解决办法(PS:opencv这种模块还没有使用过)。


一、python内存泄漏原因

讲内存泄漏原因不如了解一下python内存管理机制就明白了。网上搜索大概如下:

1,引用计数
2,垃圾回收
3,内存池

例如一个以下代码:

def func():
	a= 10
func()
print('执行到这里func函数中a变量的引用计数为0,a指向的地址为垃圾内存,即可被python回收')

以下代码函数内变量不能够被释放:

import sys
class A:
	def __init__(self):
		self.a = None
def func():
	a1 = A()
	a2 = A()
	a3 = A()
	print('a1/a2引用计数为2')
	print('a1:',sys.getrefcount(a1))
	a1.a = a2
	a2.a = a1
	print('a1:',sys.getrefcount(a1))
	a3.a = a1
	print('a1:',sys.getrefcount(a1))
	del a3# 删除a3同时减少a1的引用计数
	print('a1:',sys.getrefcount(a1))

	print(id(a2.a))
	return
	# 这个执行之后,a3引用计数满足内存释放条件
	# a1,a2 引用计数不满足内存释放条件
func()
# 执行到此,a3被回收(或者可回收状态),而a1,a2用由于相互引用,在函数func执行完之后
# 而不能够被回收,变成不可管理的垃圾内存

二、循环破解


在func退出之前对a1.a、a2.a赋予一个None值即可,解除循环引用导致垃圾内存不能够回收。

三、使用requests中的内存泄漏问题


requests由于不断循环或者使用多线程过程,递归调用requests,导致内部对象相互引用而得不到释放,导致内存使用不断累积而不能够释放。

解决办法:在使用requests函数内部,进行数据处理:只使用返回对象中状态字段、text几种字段,不要把这个返回对象进行引用。
临时解决办法:使用多进程进行处理,例如有1000个关键词要查询,需要不断递归查询直到满足某个条件退出,这用1000个多进程进行处理,每次处理10个关键词。

四、opencv内存泄漏(未解决过)