一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

(一)linux下的定時或計時操作(gettimeofday等的用法,秒,微妙,納秒)_鮑...

 haliiz 2010-05-07

一、用select()函數(shù)實現(xiàn)非阻塞時的等待時間,用到結(jié)構(gòu)體struct timeval {},這里就不多說了。

二、用gettimeofday()可獲得微妙級(0.000001秒)的系統(tǒng)時間,調(diào)用兩次gettimeofday(),前后做減法,從而達到定時或者計算時間的目的。

原型:int gettimeofday(struct timeval *tv,struct timezone *tz),會把目前的時間tv所指的結(jié)構(gòu)返回,當?shù)貢r區(qū)的信息則放到tz所指的結(jié)構(gòu)中。這兩個結(jié)構(gòu)都放在/usr/include/sys/time.h 中。

#include <stdio.h>
#include <stdlib.h> //malloc要用,沒有的話,會有警告信息:隱式聲明與內(nèi)建函數(shù)'malloc'不兼容。不過警告信息不用管也沒事

#include <assert.h>
#include <sys/time.h>

int main()
{
float time_use=0;
struct timeval start;
struct timeval end;
//struct timezone tz; //后面有說明
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

//下面的采用指針的方式也可以,但是要注意指針類型若不分配內(nèi)存的話,編譯正確,但是運行結(jié)果會不對

/*************************************************

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;//和格林威治時間差了多少分鐘
   int tz_dsttime;    //日光節(jié)約時間的狀態(tài)
}
******************************/

}

三、最小到秒的時間的獲取

int time(char cnt)
{

time_t t; //實例化time_t結(jié)構(gòu)

struct tm *timenow1; //實例化tm結(jié)構(gòu)指針
struct tm *timenow2; //實例化tm結(jié)構(gòu)指針   

time(&t);//time函數(shù)讀取現(xiàn)在的時間(國際標準時間非北京時間),然后傳值給t
timenow1=localtime(&t); //localtime函數(shù)把從time取得的時間t換算成你電腦中的時間(就是你設(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ù)把時間轉(zhuǎn)換成字符,通過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);//秒
   }

//注:如果想獲得國際標準時間,將localtime換成gmtime函數(shù)
//注:time_t是一個在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 * /
}

實際應(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)
{
//....
}

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多

    欧美在线视频一区观看| 日韩一区二区三区在线欧洲 | 六月丁香六月综合缴情| 欧美午夜国产在线观看| 日本人妻丰满熟妇久久| 日韩一区二区三区免费av| 丰满少妇被猛烈撞击在线视频| 丰满人妻一二区二区三区av| 高清一区二区三区大伊香蕉| 五月综合婷婷在线伊人| 日韩成人动作片在线观看| 国产午夜精品福利免费不| 中文日韩精品视频在线| 亚洲一区二区三区精选| 91人妻人人澡人人人人精品| 久久精品国产第一区二区三区| 精品人妻久久一品二品三品| 日本欧美一区二区三区就| 日韩欧美好看的剧情片免费| 国产伦精品一一区二区三区高清版 | 国产成人高清精品尤物| 五月婷婷综合缴情六月| 年轻女房东2中文字幕| 国产日韩综合一区在线观看| 大香蕉伊人精品在线观看| 日韩蜜桃一区二区三区| 中文字幕欧美精品人妻一区| 亚洲午夜精品视频在线| 久久免费精品拍拍一区二区| 色鬼综合久久鬼色88| 日韩精品成区中文字幕| 欧美日本道一区二区三区| 国产不卡免费高清视频| 国产内射一级一片内射高清视频| av在线免费播放一区二区| 蜜桃传媒在线正在播放| 中文字幕在线区中文色| 熟女少妇一区二区三区蜜桃| 亚洲欧美国产中文色妇| 欧美日韩国产午夜福利| 亚洲精品一区二区三区免|