一、用select()函數(shù)實(shí)現(xiàn)非阻塞時(shí)的等待時(shí)間,用到結(jié)構(gòu)體struct timeval {},這里就不多說(shuō)了。
二、用gettimeofday()可獲得微妙級(jí)(0.000001秒)的系統(tǒng)時(shí)間,調(diào)用兩次gettimeofday(),前后做減法,從而達(dá)到定時(shí)或者計(jì)算時(shí)間的目的。
原型:int gettimeofday(struct timeval *tv,struct timezone *tz),會(huì)把目前的時(shí)間tv所指的結(jié)構(gòu)返回,當(dāng)?shù)貢r(shí)區(qū)的信息則放到tz所指的結(jié)構(gòu)中。這兩個(gè)結(jié)構(gòu)都放在/usr/include/sys/time.h 中。
#include <stdio.h>
#include <stdlib.h> //malloc要用,沒(méi)有的話,會(huì)有警告信息:隱式聲明與內(nèi)建函數(shù)'malloc'不兼容。不過(guò)警告信息不用管也沒(méi)事
#include <assert.h>
#include <sys/time.h>
int main()
{
float time_use=0;
struct timeval start;
struct timeval end;
//struct timezone tz; //后面有說(shuō)明
gettimeofday(&start,NULL); //gettimeofday(&start,&tz);結(jié)果一樣
printf("start.tv_sec:%d\n",start.tv_sec);
printf("start.tv_usec:%d\n",start.tv_usec);
sleep(3);
gettimeofday(&end,NULL);
printf("end.tv_sec:%d\n",end.tv_sec);
printf("end.tv_usec:%d\n",end.tv_usec);
time_use=(end.tv_sec-start.tv_sec)*1000000+(end.tv_usec-start.tv_usec);//微秒
printf("time_use is %f\n",time_use);
//輸出:time_use is 3001410.000000
//下面的采用指針的方式也可以,但是要注意指針類(lèi)型若不分配內(nèi)存的話,編譯正確,但是運(yùn)行結(jié)果會(huì)不對(duì)
/*************************************************
struct timeval *start;
struct timeval *end;
//struct timezone *tz;
start=(struct timeval *)malloc( sizeof(struct timeval) );
assert(start!=NULL);
end=(struct timeval *)malloc( sizeof(struct timeval) );
assert(start!=NULL);
gettimeofday(start,NULL);//gettimeofday(start,tz);
printf("start->tv_sec:%d\n",start->tv_sec); //printf("(*start).tv_sec:%d\n",(*start).tv_sec);一樣
printf("start->tv_usec:%d\n",start->tv_usec);
//printf("tz->tz_minuteswest:%d\n",tz->tz_minuteswest);
//printf("tv->tz_dsttime:%d\n",tz->tz_dsttime);
sleep(3);
gettimeofday(end,NULL);//gettimeofday(end,tz);
printf("end->tv_sec:%d\n",end->tv_sec);
printf("end->tv_usec:%d\n",end->tv_usec);
time_use=(end->tv_sec-start->tv_sec)*1000+(end->tv_usec-start->tv_usec)/1000;//毫秒
printf("time_use is %f\n",time_use);
//輸出:time_use is 3001.000000
**********************************************/
/*****************************
struct timeval
{
time_t tv_sec; // seconds
suseconds_t tv_usec; // 微妙10-6
};
struct timezone
{
int tz_minuteswest;//和格林威治時(shí)間差了多少分鐘
int tz_dsttime; //日光節(jié)約時(shí)間的狀態(tài)
}
******************************/
}
三、最小到秒的時(shí)間的獲取
int time(char cnt)
{
time_t t; //實(shí)例化time_t結(jié)構(gòu)
struct tm *timenow1; //實(shí)例化tm結(jié)構(gòu)指針
struct tm *timenow2; //實(shí)例化tm結(jié)構(gòu)指針
time(&t);//time函數(shù)讀取現(xiàn)在的時(shí)間(國(guó)際標(biāo)準(zhǔn)時(shí)間非北京時(shí)間),然后傳值給t
timenow1=localtime(&t); //localtime函數(shù)把從time取得的時(shí)間t換算成你電腦中的時(shí)間(就是你設(shè)置的地區(qū))
printf("the current time1 is: %02d:%02d:%02d\n",timenow1->tm_hour,timenow1->tm_min,timenow1- >tm_sec);
printf("Local time1 is %s\n",asctime(timenow1)); //上句中asctime函數(shù)把時(shí)間轉(zhuǎn)換成字符,通過(guò)printf()函數(shù)輸出
time(&t);
timenow2=localtime(&t);
printf("the current time2 is: %02d:%02d:%02d\n",timenow2->tm_hour,timenow2->tm_min,timenow1->tm_sec);
printf("Local time2 is %s\n",asctime(timenow2));
if((timenow2->tm_hour==timenow1->tm_hour) && (timenow2->tm_min==timenow1->tm_min))
{
n=timenow2->tm_sec-timenow2->tm_sec;
printf("n is %d\n",n);//秒
}
//注:如果想獲得國(guó)際標(biāo)準(zhǔn)時(shí)間,將localtime換成gmtime函數(shù)
//注:time_t是一個(gè)在time.h中定義好的結(jié)構(gòu)體。而tm結(jié)構(gòu)體的原形如下:
/*
struct tm //最小到秒,#include <time.h>
{
int tm_sec;//seconds 0-61
int tm_min;//minutes 1-59
int tm_hour;//hours 0-23
int tm_mday;//day of the month 1-31
int tm_mon;//months since jan 0-11
int tm_year;//years from 1900
int tm_wday;//days since Sunday, 0-6
int tm_yday;//days since Jan 1, 0-365
int tm_isdst;//Daylight Saving time indicator
};
*/
}
四、納秒
函數(shù)原型:int nanosleep(const struct timespec *rqtp, struct timespec *rmtp)
其中參數(shù)timespec定義是:
struct timespec
{
time_t tv_sec; /* seconds * /
long tv_nsec; /* nanoseconds * /
}
實(shí)際應(yīng)用(部分,不完整):
struct timesepc req;
struct timespec rem;
int ret;
req.tv_sec = 2; //這就表示2秒
req.tv_nsec = 0;
ret = nanosleep(&req, &rem);
if (ret < 0)
{
//....
}
ZZ自http://www.rosoo.net/a/cpp/2010/0107/8260.html