linux中计算一段程序运行的时间

在linux系统中书写代码,经常会遇到要求计算两端程序运行的时间问题。由于经常会忘记书写,导致自己需要的时候一时查找不到,现在标记记录一下,方便下次使用。

一、clock_gettime函数

要计算代码快运行时间,要使用到clock_gettime函数,一起来简单的看下clock_gettime函数的使用。clock_gettime主要是可以用来计算精度和纳秒。

clock_gettime函数原型

int clock_gettime(clockid_t clk_id, struct timespec *tp);     

clock_gettime函数头文件

#include <time.h>

需要注意的是clockid_t clk_id,关于clk_id的具体解释
CLOCK_REALTIME:系统实时时间,随系统实时时间改变而改变,即从UTC1970-1-1 0:0:0开始计时,中间时刻如果系统时间被用户改成其他,则对应的时间相应改变。
CLOCK_MONOTONIC:从系统启动这一刻起开始计时,不受系统时间被用户改变的影响
CLOCK_PROCESS_CPUTIME_ID:本进程到当前代码系统CPU花费的时间。需要注意是不是进程开始到当前代码的时间。
CLOCK_THREAD_CPUTIME_ID:本线程到当前代码系统CPU花费的时间。需要注意是不是线程开始到当前代码的时间。

二、简单示例

自己做了一个简单的示例,测试了一下效果
ms级别时间差

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <unistd.h>
#include <string.h>

#define MY_TIMEV    struct timeval 
MY_TIMEV clockGetTime(clockid_t _tclock_id)
{
   
	struct timespec stTime;
	//该函数的时间精确到纳秒级别
	clock_gettime(_tclock_id
  • 0
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值