0

0

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

蓮花仙者

蓮花仙者

发布时间:2025-07-21 11:54:11

|

892人浏览过

|

来源于php中文网

原创

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

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

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

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

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

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

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

立即学习C++免费学习笔记(深入)”;

  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。

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

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

Anyword
Anyword

AI文案写作助手和文本生成器,具有可预测结果的文案 AI

下载

例如以下显示:

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

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

  1. 讲讲CLOCKS_PER_SEC

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

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

显示样例如下:

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

能够看见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上:

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

在RHEL6上:

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

在Solaris上:

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

在MAC上:

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

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

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

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

相关专题

更多
C语言变量命名
C语言变量命名

c语言变量名规则是:1、变量名以英文字母开头;2、变量名中的字母是区分大小写的;3、变量名不能是关键字;4、变量名中不能包含空格、标点符号和类型说明符。php中文网还提供c语言变量的相关下载、相关课程等内容,供大家免费下载使用。

397

2023.06.20

c语言入门自学零基础
c语言入门自学零基础

C语言是当代人学习及生活中的必备基础知识,应用十分广泛,本专题为大家c语言入门自学零基础的相关文章,以及相关课程,感兴趣的朋友千万不要错过了。

618

2023.07.25

c语言运算符的优先级顺序
c语言运算符的优先级顺序

c语言运算符的优先级顺序是括号运算符 > 一元运算符 > 算术运算符 > 移位运算符 > 关系运算符 > 位运算符 > 逻辑运算符 > 赋值运算符 > 逗号运算符。本专题为大家提供c语言运算符相关的各种文章、以及下载和课程。

354

2023.08.02

c语言数据结构
c语言数据结构

数据结构是指将数据按照一定的方式组织和存储的方法。它是计算机科学中的重要概念,用来描述和解决实际问题中的数据组织和处理问题。数据结构可以分为线性结构和非线性结构。线性结构包括数组、链表、堆栈和队列等,而非线性结构包括树和图等。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

258

2023.08.09

c语言random函数用法
c语言random函数用法

c语言random函数用法:1、random.random,随机生成(0,1)之间的浮点数;2、random.randint,随机生成在范围之内的整数,两个参数分别表示上限和下限;3、random.randrange,在指定范围内,按指定基数递增的集合中获得一个随机数;4、random.choice,从序列中随机抽选一个数;5、random.shuffle,随机排序。

600

2023.09.05

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

525

2023.09.20

c语言get函数的用法
c语言get函数的用法

get函数是一个用于从输入流中获取字符的函数。可以从键盘、文件或其他输入设备中读取字符,并将其存储在指定的变量中。本文介绍了get函数的用法以及一些相关的注意事项。希望这篇文章能够帮助你更好地理解和使用get函数 。

640

2023.09.20

c数组初始化的方法
c数组初始化的方法

c语言数组初始化的方法有直接赋值法、不完全初始化法、省略数组长度法和二维数组初始化法。详细介绍:1、直接赋值法,这种方法可以直接将数组的值进行初始化;2、不完全初始化法,。这种方法可以在一定程度上节省内存空间;3、省略数组长度法,这种方法可以让编译器自动计算数组的长度;4、二维数组初始化法等等。

601

2023.09.22

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

C# 教程
C# 教程

共94课时 | 7.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号