简单对比运行C与python3脚本的执行效率

开发环境:Ubuntu14.04

gcc version 4.8.4

python 3.5.3

众所周知,python是脚本语言(需要解释器一句一句解释为机器指令),而C语言则为静态语言,需要用gcc等编译器将c文件编译成系统可以执行的文件,如elf文件格式。那么,两者间的运行效率可想而知,python较C要慢很多。废话不多说,直接上简单到不能再简单的试验。

首先,编写python脚本如下:

编写C文件如下:

查看python脚本的运行时间:

先将C文件编译为a.out elf文件:

再探测a.out 的运行时间:

由此可见,python在用户态上面跑了24ms,在内核态里面跑了4ms;而由C语言编译出来的elf文件运行时间较python少之又少。

接下来,我们用strace命令测一下两者的系统调用:

执行python脚本时,由于需要打开用C语言编写的解释器Cpython,进行了多次的系统调用,而在输出log的第643行才真正地开始运行我们想要的命令。下面看一下由C语言编译的elf文件:a.out的系统调用:

仅仅用了不到30行的系统调用,就完成了“Hello, Python!”的打印。

至此,两者的运行效率差距是不是很明显地被展示出来了呢,如果你还是不知道,算我输!可为什么python还是这么流行呢?笔者的观点是,python做为开源的,第三方的库可以直接拿来用,进行傻瓜式编程,虽然运行效率低,节省了开发周期,也降低了开发成本。

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180430G0XJ6A00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券