1、延时函数
• 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、基本概念
• 什么是UTC 时间?
世界统一时间,世界各地的时间以这个为基准。
• 什么是UNIX 纪元时间?
Unix time 是指从1970 年1 月1 日00:00:00 UTC 开始所经过的秒数。在linux 中时间日期会以这种方式存储时间,有效位是秒。例如经过了1 分钟,这个数值会变大60 秒。
• 什么是格林尼治标准时(GMT)时间?
GMT 是指太阳经过英国格林尼治的时间。在英国很NX 的时候,以格林尼治为0 度经线,将世界分为24 个时区。
北京时间指的是东八区的时间,和格林尼治时间相差8 个小时。
• 什么是机器日历时间
对于Linux 来说,机器日历时间是UNIX 纪元时间。
3、时间调用
• 获取机器时间函数
• time_t time(time_t t);
– 参数t:以秒为单位的机器时间
– 返回值:如果参数为NULL,则返回机器时间;错误返回-1;
– time_t类型实际是一个long int类型
gettime.c
/*函数time头文件*/
#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;
}
4、时间转换
• 机器时间不是人类能够识别的,需要将机器时间转化为人民群众喜闻乐见的年月日时分秒的形式
• 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);
• 需要注意的是,上面几个函数的参数和以及返回值是不同的
exchangetime.c
#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;
}
5、处理器性能测试
• 高精度时间函数
• 高精度的设置时间函数和读取时间函数
• int gettimeofday(struct timeval *tv, struct timezone *tz);
• int settimeofday(const struct timeval *tv, const struct timezone *tz);
– 参数tv:用于保存获取的时间
– 参数tz:可以缺省,传入NULL
– 上面的函数比time要高6个数量级,可以达到微妙,这个精度就可以粗略的计算代码执行时间了
precisiontime,c
/*函数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);
}