针对GIL的应对措施
- 使用更高级版本python(对GIL机制进行了优化)
- 使用多进程替换多线程(多进程之间没有GIL,但是进程本身的资源消耗较多)
- 指定cpu运行线程(使用affinity模块)
- 使用Jython、IronPython等无GIL解释器
- 全IO密集型任务时才使用多线程
- 使用协程(高效的单线程模式,也称微线程;通常与多进程配合使用)
- 将关键组件用C/C++编写为Python扩展,通过ctypes使python程序直接调用C语言编译的动态链接库(wins:dll库、linux:so库)的导出函数。(with nogil 调出GIL限制)