GIL面试题
描述Python GIL的概念,以及它对python多线程的影响,并阐明多线程是否比单线程性能有提升,并解释原因。
- 1、python语言和GIL没有关系,仅仅由于历史原因CPthon解释器难以移除。
- 2、GIL:全局解释器锁,每个线程在执行的过程中都需要先获取GIL,保证每一时刻只有一个线程可以执行代码。
- 3、线程释放GIL锁的情况:在IO操作等可能会引起堵塞的system之前,可以暂时释放GIL,但在执行完毕后,必须重新获取GIL Python 3.x使用计时器(执行时间达到阈值后,当前线程释放GIL)或Python 2.x ticket计数达到100.
- 4、python使用多进程是可以利用多核的CPU资源的。
- 5、多线程爬取比多进程性能有提升,因为遇到O阻塞会自动释放GIL锁。
- 6、多线程执行IO密集型任务有优势,对计算密集型没优势,建议使用进程。
解决GIL
1、换成java解释器
2、使用其他语言写子线程
// name = 'test.c'
void DeadLoop()
{
while(1){
;
}
}
在linux系统终端中使用以下命令将test.c编译成动态库
gcc test.c -shared -o libtest.so
from ctypes import *
from threading import Thread
#动态库加载
lib = cdll.LoadLibrary("./libtest.so")
# 创建一个子线程,让其执行c语言编写的函数,此函数是一个死循环
t = Thread(target = lib.DeadLoop)
t.start()
# 主线程
while True:
pass