PyPy 如何让Python代码运行得和C一样快

目录
  • 1. 引言
  • 2. 举个栗子
  • 3. 刨根问底
    • 3.1 提前编译
    • 3.2 语言可解释性
    • 3.3 即时编译
  • 4. 总结

1. 引言

作为一名算法工程师,如何快速实现一个想法并验证它是否有效对日常工作至关重要。Python 是一个出色的工具,可以很方便地实现这一点。它允许我们专注于想法本身,而不会被繁杂的代码实现所困扰。

然而,小伙伴们一定都听说过,Python脚本语言有一个致命缺点:相比比 C 或 C++ 等编译语言Python运行慢得多。那么,在我们通过构建 Python 快速实现了一个想法之后,现在我们想将它变成一个快速且高性能的工具,我们该怎么办?通常情况下,我们最终会耗费大概两倍的时间来将 Python 代码手动转换为 C/C++。

但是如果我们的 Python 代码本身可以运行得更快,那不是很好吗?那么如何实现呢?

幸运的是,我偶然发现了该问题的解决方案:PyPy,它是 Python运行时快速的替代品。

2. 举个栗子

为了直观对比 PyPy可以提升多少加速效果,我在以下示例中同时运行了默认的 Python 解释器和 使用PyPy,

代码如下:

import time
from termcolor import colored

start = time.time()
number = 0
for i in range(100000000):
    number += i
    
print(colored("FINISHED", "green"))
print(f"Ellapsed time: {time.time() - start} s")

简单来说,上述脚本在一个循环中将 0 到 100,000,000 之间的所有整数相加,并在完成时打印一条消息和整个代码脚本运行时间。

对比结果如下:

尽管只是简单的对比,但上述例子的加速效果仍然令人兴奋。与大约需要 10 秒的默认 Python 解释器相比,PyPy 仅在 0.22 秒后就完成了执行!另外,请注意,我们可以直接将 Python 代码提供给 PyPy,而无需对代码做任何更改。

当我们将其与 C语言实现的版本进行比较时,结果会更加令人印象深刻。在我的电脑上,C 中的等效实现需要 0.32 秒。尽管在大多数情况下 C 总体上仍然是速度大师,但 PyPy 在某些情况下可以击败 C。

需要注意的是:

当我们的程序大部分运行时间都来自于调用非 python 库(比如Cpython)时,PyPy 的效率会降低。但是,如果我们有一个缓慢的程序,大部分时间都花在执行调用 Python库相关代码上时,那么 PyPy 可以极大地提升代码的运行效率。

3. 刨根问底

如果你也是第一次遇到 PyPy,那么您可能会问自己"PyPy运行这么快的背后原理是啥?"
额。。。 回顾我们的实验,我们运行完全相同的代码,并且使用 PyPy 似乎可以免费获得巨大的加速,黑科技哎。。。

其实尽管代码完全相同,但两种方式下的代码的执行方式却大不相同。 PyPy 性能提升的秘诀在于即时编译,简称 JIT 编译。

3.1 提前编译

C、C++ 以及 Swift、Haskell、Rust 等编程语言都是提前编译的。这意味着,在我们用这些语言编写了一些代码之后,需要点击一个build按钮,编译器就会将源代码转换为机器可读的代码,由一种特定的计算机架构读取。每当执行程序时,您的原始源代码早已不复存在。执行的只是机器代码。

3.2 语言可解释性

PythonJavaScriptPHP 等类似开发语言采用不同的方法。它们都是可以被解释的。与将源代码转换为机器代码相比,源代码保持不变。每次程序运行时,解释器都会逐行“查看”代码并为我们运行它。

对于 JavaScript,每个 Web 浏览器都内置了一个解释器。标准的 Python 解释器称为 CPython。但是,区分 Python 语言脚本和运行代码的解释器工具是非常重要的,那是因为我们可以拥有完全不同的工具,它们都具有运行 Python 代码的能力。这就是 PyPy 发挥作用的地方。

3.3 即时编译

PyPy 是利用即时编译的 Python 的替代实现。背后的原理是 PyPy 开始时就像一个解释器,直接从源文件运行我们的 Python 代码。但是,PyPy 不是逐行运行代码,而是在执行它们之前将部分代码编译为机器代码,可以说是及时。

从这个意义上说,JIT 编译是解释和提前编译的结合。这样,我们不仅获得了提前编译的性能提升,而且解释性语言的灵活性和跨平台可用性也保留了下来。

4. 总结

现在我们了解了 PyPy 如何实现惊人的性能提升背后的原理。在官网 pypy.org 上免费提供PyPy安装包。除了工具本身,该网站还包含大量关于微调 Python 程序以进一步提高性能的技巧。由于 PyPy 只是 Python 的一种替代实现,大多数时候它都是开箱即用,无需对 Python 项目进行任何更改。它与 Web 框架 Django、科学计算包 Numpy 和许多其他包完全兼容,推荐大家多多使用。

到此这篇关于 PyPy 如何让Python代码运行得和C一样快的文章就介绍到这了,更多相关让 Python代码运行得和C一样快内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 对Python通过pypyodbc访问Access数据库的方法详解

    看书上通过ODBC访问数据库的案例,想实践一下在Python 3.6.1中实现access2003数据库的链接,但是在导入odbc模块的时候出现了问题,后来查了一些资料就尝试着使用pypyodbc,最后成功了. 操作步骤: ①安装pypyodbc 目前Python安装通常使用steup.py或者pip工具,在python3.4之后的的版本都默认包含了pip,因此,这里推荐使用pip工具.在cmd中执行:pip install pypyodbc,耐心等待执行完成,pypyodbc模块就已经安装成功

  • 聊聊Python中的pypy

    PyPy是一个虚拟机项目,主要分为两部分:一个Python的实现和 一个编译器 PyPy的第一部分: 用Python实现的Python 其实这么说并不准确,准确得说应该是用rPython实现的Python,rPython是Python的一个子集,虽然rPython不是完整的Python,但用rPython写的这个Python实现却是可以解释完整的Python语言. PyPy的第二部分:编译器 这是一个编译rPython的编译器,或者说这个编译器有一个rPython的前端,目前也只有这么一个前端,

  • 如何用PyPy让你的Python代码运行得更快

    Python是开发人员中最常用的编程语言之一,但它有一定的局限性.例如,对于某些应用程序而言,它的运行速度可能比其它语言低100倍.这就是为什么当Python的运行速度成为用户瓶颈后,许多公司会用另一种语言重写他们的应用程序.但是有没有一种方法既可以保持Python的特性又能提高速度呢?它就是PyPy. PyPy是一种非常兼容的Python解释器,它是CPython2.7.3.6和即将推出的3.7的一种值得替代的方法.在安装和运行应用程序时使用它,可以显著提高速度.速度提高多少取决于你运行的应用

  • PyPy 如何让Python代码运行得和C一样快

    目录 1. 引言 2. 举个栗子 3. 刨根问底 3.1 提前编译 3.2 语言可解释性 3.3 即时编译 4. 总结 1. 引言 作为一名算法工程师,如何快速实现一个想法并验证它是否有效对日常工作至关重要.Python 是一个出色的工具,可以很方便地实现这一点.它允许我们专注于想法本身,而不会被繁杂的代码实现所困扰. 然而,小伙伴们一定都听说过,Python脚本语言有一个致命缺点:相比比 C 或 C++ 等编译语言Python运行慢得多.那么,在我们通过构建 Python 快速实现了一个想法之

  • PyPy 如何让Python代码运行得和C一样快

    目录 1. 引言 2. 举个栗子 3. 刨根问底 3.1 提前编译 3.2 语言可解释性 3.3 即时编译 4. 总结 1. 引言 作为一名算法工程师,如何快速实现一个想法并验证它是否有效对日常工作至关重要.Python 是一个出色的工具,可以很方便地实现这一点.它允许我们专注于想法本身,而不会被繁杂的代码实现所困扰. 然而,小伙伴们一定都听说过,Python脚本语言有一个致命缺点:相比比 C 或 C++ 等编译语言Python运行慢得多.那么,在我们通过构建 Python 快速实现了一个想法之

  • 使用memory_profiler监测python代码运行时内存消耗方法

    前几天一直在寻找能够输出python函数运行时最大内存消耗的方式,看了一堆的博客和知乎,也尝试了很多方法,最后选择使用memory_profiler中的mprof功能来进行测量的,它的原理是在代码运行过程中每0.1S统计一次内存,并生成统计图. 具体的使用方式如下: 首先安装memory_profiler和psutil(psutil主要用于提高memory_profile的性能,建议安装)(可使用pip直接安装) pip install memory_profiler pip install p

  • Python在线运行代码助手

    Python代码运行助手可以让你在线输入Python代码,然后通过本机运行的一个Python脚本来执行代码.原理如下: 在网页输入代码: 点击Run按钮,代码被发送到本机正在运行的Python代码运行助手: Python代码运行助手将代码保存为临时文件,然后调用Python解释器执行代码: 网页显示代码执行结果: 下载 点击右键,目标另存为:learning.py 备用下载地址:learning.py 完整代码: #!/usr/bin/env python3 # -*- coding: utf-

  • python如何使用代码运行助手

    python代码运行助手是能在网页上运行python语言的工具.因为python的运行环境在很多教程里都是用dos的,黑乎乎的界面看的有点简陋,所以出了这python代码运行助手,作为ide. 实际上,python代码运行助手界面只能算及格分,如果要找ide,推荐使用jupyter.jupyter被集成到ANACONDA里,只要安装了anacoda就能使用了. 1.要打开这运行助手首先要下载一个learning.py,如果找不到可以复制如下代码另存为"learning.py",编辑器用

  • Python 代码性能优化技巧分享

    如何进行 Python 性能优化,是本文探讨的主要问题.本文会涉及常见的代码优化方法,性能优化工具的使用以及如何诊断代码的性能瓶颈等内容,希望可以给 Python 开发人员一定的参考. Python 代码优化常见技巧 代码优化能够让程序运行更快,它是在不改变程序运行结果的情况下使得程序的运行效率更高,根据 80/20 原则,实现程序的重构.优化.扩展以及文档相关的事情通常需要消耗 80% 的工作量.优化通常包含两方面的内容:减小代码的体积,提高代码的运行效率. 改进算法,选择合适的数据结构 一个

  • 让Python代码更快运行的5种方法

    不论什么语言,我们都需要注意性能优化问题,提高执行效率.选择了脚本语言就要忍受其速度,这句话在某种程度上说明了Python作为脚本语言的不足之处,那就是执行效率和性能不够亮.尽管Python从未如C和Java一般快速,但是不少Python项目都处于开发语言领先位置. Python很简单易用,但大多数人使用Python都知道在处理密集型cpu工作时,它的数量级依然低于C.Java和JavaScript.但不少第三方不愿赘述Python的优点,而是决定自内而外提高其性能.如果你想让Python在同一

  • python程序运行进程、使用时间、剩余时间显示功能的实现代码

    有很多程序运行时间比较长,如果不将运行过程输出将很难判断程序运行的时间.下边这段程序将按照上图所示的格式输出程序运行进程.已用时间.剩余时间. def time_change(time_init): #定义将秒转换为时分秒格式的函数 time_list = [] if time_init/3600 > 1: time_h = int(time_init/3600) time_m = int((time_init-time_h*3600) / 60) time_s = int(time_init

  • python如何统计代码运行的时长

    1. 背景 有时候,需要统计一段代码运行所用的时长,则可以用到下面的代码. 2. 代码示例 #!/usr/bin/env python import datetime import time start_time = datetime.datetime.now() time.sleep(5) end_time = datetime.datetime.now() delta = end_time - start_time delta_gmtime = time.gmtime(delta.total

随机推荐