目前主要是使用获取从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位的数据进行转换,这里可能会导致计算出错。

Logo

更多推荐