clock_gettime函数
函数介绍
基于Linux-C的时间函数,可以用于计算精度和纳秒
函数原型
#include<time.h>
int clock_gettime(clockid_t clk_id,struct timespec *tp);
参数:
- clk_id: 检索和设置的clk_id指定的时钟时间。
- CLOCK_REALTIME:系统实时时间,随系统实时时间改变而改变,即从UTC1970-1-1 0:0:0开始计时,中间时刻如果系统时间被用户改成其他,则对应的时间相应改变。
- CLOCK_MONOTONIC:从系统启动这一刻起开始计时,不受系统时间被用户改变的影响。
- CLOCK_PROCESS_CPUTIME_ID:本进程到当前代码系统CPU花费的时间。需要注意是不是进程开始到当前代码的时间。
- CLOCK_THREAD_CPUTIME_ID:本线程到当前代码系统CPU花费的时间。需要注意是不是线程开始到当前代码的时间。
-
tp:
struct timespec
{
__time_t tv_sec; // 秒 long
__syscall_slong_t tv_nsec; // 纳秒 long
};
示例代码
#include <stdio.h>
#include <time.h>
#include <stdint.h>
#include <unistd.h>
static uint32_t get_tick_count()
{
struct timespec ts;
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &ts); // 获取从系统启动到现在的时间
printf("tv_sec=%ld\ntv_nsec=%ld\n\n",ts.tv_sec,ts.tv_nsec);
return (ts.tv_sec * 1000 + ts.tv_nsec / 1000000); // 返回毫秒
}
int main()
{
int sum = 0;
for(int i = 0; i < 1000000000; i++)
{
sum += i;
}
printf("time=%d\n",get_tick_count());
return 0;
}