Unix/Linux环境C编程新手教程(22) C/C++怎样获取程序的执行时间「建议收藏」

发布时间 - 2025-07-21 00:00:00    点击率:

大家好,又见面了,我是全栈君。

  1. 问:知道程序执行时间我们能够做什么?

在《C++应用程序性能优化》一书中,相信大家对性能优化这一块一定很上心,书中通过对比优化前后的时间给我们直观的感受。

那么,我们如何利用C语言提供的库函数获取一个应用程序各阶段的执行效率,通过数据分析出该程序的瓶颈并进行优化呢?

本文将为大家介绍clock()函数。

  1. 我们首先看一看C/C++标准文档对于clock()函数的解说

  1. 函数原型 clock_t clock (void);

函数返回值:clock()返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock tick)数。

Returns the processor time consumed by the program. 返回程序所消耗的处理器时间。

  1. 两个重要的概念需要理解一下

epoch:时间点。

时间点在标准C/C++中是一个整数,它用此时的时间和标准时间点相差的秒数(即日历时间)来表示。

通过时钟作为参考的划时代系统有所不同,但它是关系到执行程序(通常是它的启动)。要计算一个程序的实际处理时间,由时钟返回的值应比由曾经调用同一个函数返回的一个值。

clock tick:时钟计时单元,一个时钟计时单元的时间长短是由CPU控制的。一个clock tick不是CPU的一个时钟周期,而是C/C++的一个基本计时单位。

  1. clock函数

The value returned is expressed in clock ticks, which are units of time of a constant but system-specific length (with a relation of CLOCKS_PER_SEC clock ticks per second). 返回的值是以时钟计时单元为单位表示,这是一个恒定的但系统特定长度的时间单位(CLOCKS_PER_SEC表示每秒多少时钟计时单元)。

The epoch used as reference by clock varies between systems, but it is related to the program execution (generally its launch). To calculate the actual processing time of a program, the value returned by clock shall be compared to a value returned by a previous call to the same function.

时间点所参考的时钟在不同系统间有所不同,它是关系到程序执行(通常是它的启动)。要计算一个程序的实际处理器占用时间,由时钟返回的值应与曾经调用同一个函数返回的一个值相比。

参数:none 没有

返回值:The number of clock ticks elapsed since an epoch related to the particular program execution. On failure, the function returns a value of -1. 假设失败,函数返回值是-1。

一句话,这个函数的作用就是:启动这个程序到程序中调用clock()函数时之间的CPU时钟计时单元(clock tick)的计数。

举一个样例。调用clock的地方就像是我们在体育赛场上掐秒表的动作。

100m开跑计时员开始计时,第一个到达终点掐一下显示的时间是9.502s,第二个是9.559s。

9.502s和9.559s都是从开始赛跑到终点的计时。这就好比我们的程序开始启动了,我们在一些可能造成性能瓶颈的地方前掐秒表——调用clock()函数一下,完了再掐一下秒表,通过计算两次掐表的间隔来评估瓶颈的严重程度。

  1. 讲讲clock_t

clock_t是一个定义在ctime头文件里的类型,作为一个基本数据类型的别名。

在C语言中,clock_t定义的头文件就是time.h。

我们打开自己所在开发环境中的time.h,搜索一下clock_t便能够找到。

例如以下显示:

从上如我们能够知道所谓的clock_t事实上就是一个long型。

  1. 讲讲CLOCKS_PER_SEC

前面我知道CLOCKS_PER_SEC是某一个特定的值。

进入time.h和查看clock_t的方法一样找到CLOCKS_PER_SEC。

显示样例如下:

能够看见CLOCKS_PER_SEC是一个宏,意味着在全部出现CLOCKS_PER_SEC的地方在编译的时候就会被替换成1000这个数值。

  1. 小试牛刀

现在我们就试验一下,我通过编写3个函数testinit()、testwork()、testend()来模拟程序执行的一些模块的执行时间。

代码语言:javascript 代码运行次数:0

运行 复制
#include       /* printf */
#include        /* clock_t, clock, CLOCKS_PER_SEC */
#include        /* sqrt */

int testinit (int n) { int num = n * n; while(num) { --num; } return 0; }

int testwork (int n) { printf ("Begin Calculating...\n"); int i,j; int freq=n-1; for (i=2; i<=n; ++i) { for (j=sqrt(i); j>1;--j) if (i%j==0) { --freq; break; } } return freq; }

int testend (int n) { int num = n * n; while(num) { --num; } return 0; }

int main () { clock_t t; int f;

//测试第一阶段 初始化 printf ("Begin clock...\n"); t = clock(); //第一个clock() t表示从程序启动到现在这个时刻的时间 testinit(1500); t = clock() - t; //第二次调用clock()减去第一次获得的t的差值为两次掐表的间隔 printf ("It took %d clicks (%f seconds) to call testinit().\n",t,((float)t)/CLOCKS_PER_SEC);

//测试第二阶段 工作 t = clock(); //第一个clock() t表示从程序启动到现在这个时刻的时间 f = testwork(99999); t = clock() - t; //第二次调用clock()减去第一次获得的t的差值为两次掐表的间隔 printf ("It took %d clicks (%f seconds)to call testwork().\n",t,((float)t)/CLOCKS_PER_SEC); printf ("The number of primes lower than 100,000 is: %d\n",f);

//测试第三阶段 t = clock(); //第一个clock() t表示从程序启动到现在这个时刻的时间 testend(1255); t = clock() - t; //第二次调用clock()减去第一次获得的t的差值为两次掐表的间隔 printf ("It took %d clicks (%f seconds)to call testend().\n",t,((float)t)/CLOCKS_PER_SEC);

return 0; }

通过比对数据我们分析出testwork()函数耗时较大,很可能就是项目中的瓶颈。

  1. 以下我们看看这个程序在各个平台的Unix/Linux执行情况如何呢?

在RHEL7上:

在RHEL6上:

在Solaris上:

在MAC上:

发布者:全栈程序员栈长,转载请注明出处:https://www./link/de9cf7fc237bf2217c1c576e4f026fee

原文链接:https://www./link/c8377ad2a50fb65de28b11cfc628d75c


# linux  # c语言  # 处理器  # ai  # c++  # red  # JavaScript  # html  # 数据类型  # void  #   # Length  # number  # function  # 数据分析  # https  # 性能优化  # unix  # 第一个  # 两次  # 是一个  # 值为  # 返回值  # 执行时间  # 它是  # 有所不同  # 关系到  # 应用程序 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 动图在线制作网站有哪些,滑动动图图集怎么做?  Laravel如何处理异常和错误?(Handler示例)  电商网站制作价格怎么算,网上拍卖流程以及规则?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  Claude怎样写约束型提示词_Claude约束提示词写法【教程】  Laravel怎么实现验证码(Captcha)功能  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  太平洋网站制作公司,网络用语太平洋是什么意思?  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  怎么用AI帮你为初创公司进行市场定位分析?  google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤  javascript中对象的定义、使用以及对象和原型链操作小结  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  Angular 表单中正确绑定输入值以确保提交与验证正常工作  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  ,网页ppt怎么弄成自己的ppt?  如何安全更换建站之星模板并保留数据?  Laravel如何实现API版本控制_Laravel版本化API设计方案  如何在VPS电脑上快速搭建网站?  JavaScript Ajax实现异步通信  Laravel如何配置Horizon来管理队列?(安装和使用)  Linux网络带宽限制_tc配置实践解析【教程】  如何在Tomcat中配置并部署网站项目?  济南网站建设制作公司,室内设计网站一般都有哪些功能?  Java垃圾回收器的方法和原理总结  如何用PHP快速搭建CMS系统?  潮流网站制作头像软件下载,适合母子的网名有哪些?  如何用AWS免费套餐快速搭建高效网站?  *服务器网站为何频现安全漏洞?  HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】  如何用JavaScript实现文本编辑器_光标和选区怎么处理  实例解析angularjs的filter过滤器  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  如何在Windows环境下新建FTP站点并设置权限?  Linux系统命令中tree命令详解  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  详解Huffman编码算法之Java实现  Laravel如何自定义分页视图?(Pagination示例)  创业网站制作流程,创业网站可靠吗?  Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】  Win11怎么设置默认图片查看器_Windows11照片应用关联设置  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录  高端云建站费用究竟需要多少预算?  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  百度输入法ai组件怎么删除 百度输入法ai组件移除工具