编程语言分类概念介绍(编译型语言、解释型语言、静态类型语言、动态类型语言概念与区别)

https://www.cnblogs.com/zhoug2020/p/5972262.html

Python解释器

一般使用的Python解释器CPython:是用C语言实现Pyhon,是目前应用最广泛的解释器。最新的语言特性都是在这个上面先实现,基本包含了所有第三方库支持,但是CPython有几个缺陷,一是全局锁使Python在多线程效能上表现不佳,二是CPython无法支持JIT(Just-in-time compliation即时编译),导致其执行速度不及Java和Javascipt等语言。于是出现了Pypy。

Pypy:是用Python自身实现的解释器。针对CPython的缺点进行了各方面的改良,性能得到很大的提升。最重要的一点就是Pypy集成了JIT。但是,Pypy无法支持官方的C/Python API,导致无法使用例如Numpy,Scipy等重要的第三方库。(还有JPython,IronPython等)

全局解释器锁

全局解释器锁(Global Interpreter Lock)是Python用于同步线程的工具,使得任何时刻仅有一个线程在执行。

Python GIL被动释放机制(抢占机制)

如果一个线程不间断地在 Python 2 中运行100次解释器的计步(ticks)(可以通过sys.setcheckinterval()设置计步长度),或者不间断地在 Python 3 运行15 毫秒,那么它便会放弃 GIL,而其他线程可以运行。

全局解释器锁带来的问题

多线程Python程序无法充分利用多个CPU核心带来的优势。

(主要影响CPU密集型程序,I/O密集型程序使用多线程一般是明智的选择)

解决方法

1,使用多进程

原理:每个进程分配不同的解释器,有单独的GIL。

缺点:额外产生数据序列化与通信的开销。

注意点:待执行操作需包含在以def语句定义的Python函数中(即,在这里lambda,闭包,可调用实例都是不可以的),而且函数参数和返回值必须兼容pickle编码。

使用方法:廖雪峰Python教程-多进程部分

2,使用C语言扩展模块

原理:C语言扩展程序的执行保持与Python解释器隔离,在C代码中释放GIL。

缺点:调用C函数时GIL会被锁定,若阻塞,解释器无法释放GIL。

注意点:确保C代码可以独立于Python执行。(不使用Python的数据结构,也不调用Python的C语言API)

使用方法:在C代码中插入特殊的宏或是使用其他工具来访问C代码,如ctypes库或者Cython。(ctypes默认会在调用C代码时自动释放GIL)

使用ctypes访问C代码教程

3,选用其他没有GIL的解释器代替CPython

原理:使用没有GIL的解释器实现。

缺点:不完全兼容。

使用方法:目前Jython和IronPython没有GIL。

Jython文档,IronPython官网

更多相关文章

  1. 八大经典排序算法基本思想及代码实现(插入排序,希尔排序,选择排序,
  2. UNIX-LINUX编程实践教程->第八章->实例代码注解->写一个简单的sh
  3. Linux下objdump查看C程序编译后的汇编代码
  4. Linux-C语言函数手册
  5. linux下的C语言编程(总结篇)
  6. C语言文件I/O 读取一个文件并输出出来 和 输出到另一个文件里面
  7. 软交换FreeSWITCH系统概要和源代码分析预备知识
  8. 如何卸载内核代码中的文件系统
  9. linux vim下如何让类似txt的文本,呈现出某种语言的高亮形式?

随机推荐

  1. android获得mac和ip .
  2. Android AnimationDrawable动画实例
  3. Android手势控制实现缩放、移动图片
  4. android R文件生成错误
  5. Android调用拨号按钮CALL_BUTTON
  6. google apis 下载
  7. Android 获取屏幕尺寸与密度
  8. Android对话框图片全屏
  9. Android之解析JSON数据示例(android原生态
  10. android 创建动态View