日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > linux >内容正文

linux

Linux获取毫秒级时间

發(fā)布時(shí)間:2025/4/16 linux 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Linux获取毫秒级时间 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

在軟件設(shè)計(jì)中經(jīng)常會(huì)用到關(guān)于時(shí)間的處理,用來(lái)計(jì)算語(yǔ)句、函數(shù)的執(zhí)行時(shí)間,這時(shí)就需要精確到毫秒甚至是微妙的時(shí)間。

?

int gettimeofday(struct timeval *tv, struct timezone *tz);

int settimeofday(const struct timeval *tv?, const struct timezone *tz);

?

struct timeval {

??? time_t????? tv_sec;???? /* seconds */

??? suseconds_t tv_usec;??? /* microseconds */

};

?

struct timezone {

??? int tz_minuteswest;???? /* minutes west of Greenwich */

??? int tz_dsttime;???????? /* type of DST correction */

};

?

下面是個(gè)簡(jiǎn)單的例子,用來(lái)統(tǒng)計(jì)程序的執(zhí)行時(shí)間:

?????? …

struct timeval t_start,t_end;

??? long cost_time = 0;

?

//get start time

gettimeofday(&t_start, NULL);

printf("Start time: %ld us", t_start.tv_usec);

?

//some operation

?

//get end time

gettimeofday(&t_end, NULL);

printf("End time: %ld us", t_end.tv_usec);

?

//calculate time slot

cost_time = t_end.tv_usec - t_start.tv_usec;

printf("Cost time: %ld us", cost_time);

?

輸出:

Start time: 438061 us

End time: 459867 us

Cost time: 21806 us

?

demo:

#include <stdio.h> #include <stdlib.h> #include <sys/time.h> int main(int argc, char *argv[]) { printf("Hello, world!\n"); struct timeval tvafter,tvpre; struct timezone tz; int sum = 0; int i=0; gettimeofday (&tvpre , &tz);for(i = 0; i < 100000000; i++) {sum += i; } gettimeofday (&tvafter , &tz); printf("sum=%d 花費(fèi)時(shí)間:%d\n",sum, (tvafter.tv_sec-tvpre.tv_sec)*1000+(tvafter.tv_usec-tvpre.tv_usec)/1000); return EXIT_SUCCESS; }

總結(jié)

以上是生活随笔為你收集整理的Linux获取毫秒级时间的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。