1. 延时

1.1 基本知识

linux中延时函数很简单,却经常用到。在操作系统中和单片机处理延时方式就完全不一样了,不可能是使用
for循环浪费系统资源。而是有专门的接口函数
• linux系统编程中常用的延时函数:
– sleep、usleep等
• linux内核中的常用的延时函数:
– ndelay、udelay、mdelay等
函数sleep 是秒延时
• unsigned int sleep(unsigned int seconds);
– 例如:sleep(1),即延时一秒。
– 返回值:无符号的整形数值,如果延时成功则返回0,如果延时过程中被打断,则返回剩余的秒数。例如sleep(5),返回值为3,那么实际延时就是5-3=2 秒
函数usleep 是微秒延时
• int usleep(useconds_t usec);
– Useconds 需要小于1000000
– 例如:usleep(10),表示延时10 微秒。
– 延时成功则返回0,失败则返回-1

2. 时间

2.1 基本概念

下面介绍一下四种时间的概念:
UTC时间: 协调世界时,又称世界统一时间,世界标准时间,国际协调时间。
UNIX纪元时间:UNIX时间又称POSIX时间/新纪元时间(Epoch Time),从协调世界时1970年1月1日0时0分0秒起到现在的总秒数,不包括闰秒。正值表示1970以後,负值则表示1970年以前。
GMT格林尼治标准时间:格林尼治标准时间是指位于英国伦敦郊区的皇家格林尼治天文台的标准时间。
机器日历时间:机器日历时间在一定程序上相当于UNIX时间

2.2 时间调用

机器时间函数
• time_t time(time_t *t);
– 参数 *t:以秒为单位的机器时间
– 返回值:如果参数为NULL,则返回机器时间;错误返回-1;
– time_t类型实际是一个long int类型
实例如下:

#include<time.h>
#include<stdio.h> 

int main(void)
{
	//定义一个结构体变量
	time_t timep;
	//获取以秒为单位时间
	time(&timep);
	//打印当前机器时间
	printf("UTC time: 0x%08x\n", timep);
	//获取机器时间
	timep = time(NULL);
	printf("UTC time: 0x%08x\n", timep);
	return 0;
}
2.3 时间转换

机器时间不是人类能够识别的,需要将机器时间转化常见的年月日时分秒的形式。需要用到的函数与结构体为:
tm结构体
– 包含tm_sec;tm_min;tm_hour;int tm_mday等等成员
– 函数ctime

将时间转化为字符串格式
• char *ctime(const time_t *timep);

将时间转化为格林威治时间
• struct tm *gmtime(const time_t *timep);

时间转换为字符格式,注意这个函数的参数是tm 结构的
• char *asctime(const struct tm *tm);

时间转化为本地时间
• struct tm *localtime(const time_t *clock);
实例如下:

#include <stdio.h>
#include <time.h>

int main(void){
	time_t timep;
	struct tm *tblock;
	
	time(&timep);
	printf("ctime/timep is %s\n",ctime(&timep));
	
	printf("asctime is %s\n",asctime(gmtime(&timep)));
	
	tblock = localtime(&timep);
	printf("localtime is :%s\n",asctime(tblock));
	printf("localtime is:%s\n",ctime(&timep));
	return 0;
}
2.4 处理器性能测试

高精度的设置时间函数和读取时间函数
• int gettimeofday(struct timeval *tv, struct timezone *tz);
• int settimeofday(const struct timeval *tv, const struct timezone
*tz);
– 参数tv:用于保存获取的时间
– 参数tz:可以缺省,传入NULL
– 上面的函数比time要高6个数量级,可以达到微妙,这个精度就可以粗略
的计算代码执行时间了。
实例如下:

/*函数time头文件*/
#include<time.h>
/*函数gettimeofday和settimeofday的头文件*/
#include<sys/time.h>
#include<stdio.h>

void function() 
{ 
	 unsigned int i,j; 
	 double y; 
	 for(i=0;i<1000;i++) 
	 for(j=0;j<1000;j++) 
	 y=i/(j+1); //耗时操作
} 

main() 
{ 
	struct timeval tpstart,tpend; 
	float timeuse; 

	gettimeofday(&tpstart,NULL); //记录开始时间
	function();
	
	gettimeofday(&tpend,NULL); //记录结束时间
	
	timeuse = 1000000*(tpend.tv_sec-tpstart.tv_sec)+ 
	tpend.tv_usec-tpstart.tv_usec; //计算差值
	timeuse /= 1000000; 
	
	printf("Used Time:%f\n",timeuse); 
}
Logo

更多推荐