GIL(全局解释锁)
1.每个线程在执行过程都需要GIL,保证同一时刻只有一个线程可以执行代码(避免共享全局变量问题)
2.Python多线程本质上没有提高CPU利用率
3.由于历史原因,Cpython虚拟机(解释器)无法移除GIL
4.所以这个问题是解释器的问题,不是Python语言本身的问题
5.其他语言写的解释器没有GIL
6.线程释放GIL锁的情况:在IO操作等可能会引起阻塞的system call之前,线程可以暂时释放GIL,但执行完毕后必须重新获取GIL。python3通过计时器(超时就释放GIL),python2 tickets计数到100释放
7.因为遇到IO阻塞会自动释放GIL锁,多线爬虫程比单线程性能有提升
结论:GIL只会影响计算密集型程序(用多进程可解决),对IO密集型程序影响较小
多线程:利用线程等待时间去执行其他线程
多协程(单线程):利用代码等待时间去执行其他代码
Python调用C动态库
from ctypes import *
from threading import Thread
#加载动态库
lib = cdll.LoadLibrary("./libdead_loop.so")
#创建一个子线程,让其执行c语言编写的函数,此函数是一个死循环
t = Thread(target=lib.DeadLoop)
t.start()
#主线程
while True:
pass