聊聊Python中的pypy


Posted in Python onJanuary 12, 2018

PyPy是一个虚拟机项目,主要分为两部分:一个Python的实现和 一个编译器

PyPy的第一部分: 用Python实现的Python

  其实这么说并不准确,准确得说应该是用rPython实现的Python,rPython是Python的一个子集,虽然rPython不是完整的Python,但用rPython写的这个Python实现却是可以解释完整的Python语言。

PyPy的第二部分:编译器

这是一个编译rPython的编译器,或者说这个编译器有一个rPython的前端,目前也只有这么一个前端,不过它的后端却是不少,也就是说这个编译器支持许多的目标语言,比较重要的有:C,CIL,JavaScript...

第一部分看成pypy(1)第二部分看成pypy(2)

为什么你在同一层面下同时需要这两者?你可以这样想一下:PyPy(1)是一个用RPython写的解释器,因此它能加载用户的Python代码并将它编译成字节码。但是这个用RPython写的解释器本身要能运行,就必须要被另外一个Python实现去解释。我们可以直接用CPython去.运行这个解释器。但是这个还不够快取而代之,我们使用了PyPy(2)去编译这个PyPy的解释器,生成其他平台(比如C,JVM或CLI)代码在我们的机器上运行,并且还加入了JIT特性。JIT能够把字节码转换成机器语言,pypy之所以快,是因为它整合了JIT跟踪技术的优化编译器。

pypy性能测试

聊聊Python中的pypy

聊聊Python中的pypy

Cpython2.7.6,pyston0.2,pypy2.2.1的性能对比,使用的是pyston源代码目录下的minibenchmarks和microbenchmarks中
的python代码来跑,对比结果如下表所示

 

  Cpython2.7.6 pyston0.2
microbenchmarks
attribute_lookup.py 258.544s 200.387s 2.667s
attrs.py 0.622s 1.658s 0.086s
closures.py 0.485s 6.658s 0.058s
empty_loop.py 3.532s 19.248s 0.248s
fib2.py 3.375s 0.669s 0.804s
fib.py 3.696s 0.636s 0.864s
function_calls.py 5.283s 0.878s 0.303s
gcj_2014_2_b.py 1.527s 45.803s 0.276s
gcj_2014_3_b.py 0.022s 0.174s 0.069s
iteration.py 0.185s 1.242s 0.062s
lcg.py 2.910s 9.097s 0.235s
listcomp_bench.py 10.132s 56.170s 1.379s
nested.py 0.368s 6.828s 0.057s
polymorphism.py 4.358s 4.390s 14.260s
prime_summing.py 20.197s 43.779s 1.250s
pydigits.py 0.034s Failed 0.039s
repatching.py 0.475s 0.384s 0.061s
simple_sum.py 0.075s 0.578s 0.040s
sort.py 2.216s 4.587s 0.135s
thread_contention.py 6.486s 8.133s 0.240s
thread_uncontended.py 1.324s 5.823s 0.238s
unwinding.py 1.082s 93.180s 4.481s
vecf_add.py 9.890s Failed 0.059s
vecf_dot.py 4.944s 8.434s 0.062s
minibenchmarks
allgroup.py 0.836s Failed 18.804s
chaos.py 26.268s Failed 1.392s
fannkuch_med.py 0.990s 1.898s 0.325s
fannkuch.py 10.952s 20.834s 2.057s
Go.py 53.787s Failed 33.638s
interp2.py 5.521s 10.124s 0.701s
interp.py 10.863s 5.035s 0.563s
nbody_med.py 3.132s 6.642s 0.601s
nbody.py 12.677s 25.540s 1.470s
nq.py 29.879s Failed 44.418s
raytrace.py 11.608s Failed 1.228s
spectral_norm.py: 14.388s 118.309s 1.333s

pypy编译除了有颜色背景的数据,其它测试结果基本都是最快的,其中15个程序代码测试结果所花时间不到Cpython的十分之一

pypy的缺陷

可以看出pypy实现python有很大的优势,但是目前来说很多公司的python项目仍然没有采用pypy来实现,原因是

pypy有一个缺陷:C扩展性弱,简单理解就是python程序中如果混合了C/C++代码,调用了C/C++的库,就会导pypy

不支持或者pypy运行速度变慢很多。而现在很多项目都是采用C/C++/Python混合编程。

但是pypy也有自己的兼容C/C++的方法(但是没有完全解决扩展性弱的问题),pypy有ctypes和cffi两种方式来

进行C扩展,以下是一些简单程序实验:

用ctypes的方式实现C++,python混合编程,先写一个.cpp然后在python文件中调用它,最后用Cpython,和pypy分别编译执行都可以跑,说明ctypes是支持C++扩展的

聊聊Python中的pypy

聊聊Python中的pypy

聊聊Python中的pypy

这次用pypy跑的速度就要Cpython不少了

总结

以上就是本文关于聊聊Python中的pypy的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

Python 相关文章推荐
Python中用Decorator来简化元编程的教程
Apr 13 Python
Python3结合Dlib实现人脸识别和剪切
Jan 24 Python
python实现列表中由数值查到索引的方法
Jun 27 Python
OpenCV 模板匹配
Jul 10 Python
春节到了 教你使用python来抢票回家
Jan 06 Python
TensorFlow 输出checkpoint 中的变量名与变量值方式
Feb 11 Python
找Python安装目录,设置环境路径以及在命令行运行python脚本实例
Mar 09 Python
Python configparser模块封装及构造配置文件
Aug 07 Python
解决python和pycharm安装gmpy2 出现ERROR的问题
Aug 28 Python
python如何发送带有附件、正文为HTML的邮件
Feb 27 Python
python爬虫请求库httpx和parsel解析库的使用测评
May 10 Python
如何在pycharm中快捷安装pip命令(如pygame)
May 31 Python
Python中实现switch功能实例解析
Jan 11 #Python
Python中getpass模块无回显输入源码解析
Jan 11 #Python
python版微信跳一跳游戏辅助
Jan 11 #Python
微信跳一跳python辅助脚本(总结)
Jan 11 #Python
Python用sndhdr模块识别音频格式详解
Jan 11 #Python
Python用imghdr模块识别图片格式实例解析
Jan 11 #Python
Python实现可设置持续运行时间、线程数及时间间隔的多线程异步post请求功能
Jan 11 #Python
You might like
phplist及phpmailer(组合使用)通过gmail发送邮件的配置方法
2016/03/30 PHP
php curl获取到json对象并转成数组array的方法
2018/05/31 PHP
Javascript基础教程之switch语句
2015/01/18 Javascript
jQuery中DOM操作实例分析
2015/01/23 Javascript
JQuery EasyUI的使用
2016/02/24 Javascript
JQuery 设置checkbox值二次无效的解决方法
2016/07/22 Javascript
jQuery将表单序列化成一个Object对象的实例
2016/11/29 Javascript
Vue-cli 使用json server在本地模拟请求数据的示例代码
2017/11/02 Javascript
微信小程序 scroll-view实现锚点滑动的示例
2017/12/06 Javascript
redux中间件之redux-thunk的具体使用
2018/04/17 Javascript
webstorm中配置nodejs环境及npm的实例
2018/05/15 NodeJs
使用typescript构建Vue应用的实现
2019/08/26 Javascript
在IPython中进行Python程序执行时间的测量方法
2018/11/01 Python
Python使用numpy模块实现矩阵和列表的连接操作方法
2019/06/26 Python
django中SMTP发送邮件配置详解
2019/07/19 Python
python获取array中指定元素的示例
2019/11/26 Python
np.dot()函数的用法详解
2020/01/17 Python
Python编程快速上手——Excel表格创建乘法表案例分析
2020/02/28 Python
python 对象真假值的实例(哪些视为False)
2020/12/11 Python
美国顶级奢侈茶:Mighty Leaf Tea(美泰茶)
2016/11/26 全球购物
公司门卫管理制度
2014/02/01 职场文书
公司中秋节活动方案
2014/02/12 职场文书
员工试用期考核自我鉴定
2014/04/13 职场文书
慈善晚会策划方案
2014/05/14 职场文书
2014预备党员批评与自我批评思想汇报
2014/09/20 职场文书
党的群众路线批评与自我批评发言稿
2014/10/16 职场文书
预备党员期盼十八届四中全会召开思想汇报
2014/10/17 职场文书
北京颐和园导游词
2015/01/30 职场文书
2015年党总支工作总结
2015/05/25 职场文书
怒海潜将观后感
2015/06/11 职场文书
2016年9月份红领巾广播稿
2015/12/21 职场文书
预备党员入党思想汇报(范文)
2019/08/14 职场文书
创业计划书之校园跑腿公司
2019/09/24 职场文书
python如何做代码性能分析
2021/04/26 Python
你真的了解PHP中的引用符号(&)吗
2021/05/12 PHP
配置Kubernetes外网访问集群
2022/03/31 Servers