目前主要是使用获取从1970年1月1日之后的秒数。
用户态:
struct timeval time = {
.tv_sec=0, /*单位:s*/
.tv_usec=0 /*单位:ns*/
};
unsigned long long int sec,usec = 0;
clock_gettime(0, &time);
sec = (unsigned long long int)time.tv_sec;
usec = (unsigned long long int)time.tv_usec;
return sec*1000000 + usec/1000;
这里clock_gettime的功能比较丰富,精度是纳秒,根据第一个参数可以获取不同的时间:
CLOCK_REALTIME:系统实时时间,随系统实时时间改变而改变,即从UTC1970-1-1 0:0:0开始计时,
中间时刻如果系统时间被用户改成其他,则对应的时间相应改变
CLOCK_MONOTONIC:从系统启动这一刻起开始计时,不受系统时间被用户改变的影响
CLOCK_PROCESS_CPUTIME_ID:本进程到当前代码系统CPU花费的时间
CLOCK_THREAD_CPUTIME_ID:本线程到当前代码系统CPU花费的时间
注意:如果是想要将秒与纳秒拼接的话,请注意数据类型的转换,普通的32位数据会截断(秒已经就有10位了,11位就超过了范围。)
32位系统的long也是32位,请使用Long long .
内核态:
struct timeval time = {
.tv_sec=0, /*单位:s*/
.tv_usec=0 /*单位:us*/
};
unsigned long long int sec,usec = 0;
do_gettimeofday(&time);
sec = (unsigned long long int)time.tv_sec;
usec = (unsigned long long int)time.tv_usec;
return sec*1000000 + usec;
这里获取的是从UTC1970-1-1 0:0:0开始计时的时间。
注意:内核态的64位的运算支持可能不全,直接使用/可能会出问题,需要使用do_div。
另外注意类型不用使用long等32位的数据进行转换,这里可能会导致计算出错。