struct timeval 計時問題


linux編程中,如果用到計時,可以用struct timeval獲取系統時間。struct timeval的函數原型如下:

struct timeval { 
__kernel_time_t tv_sec; /* seconds */ 
__kernel_suseconds_t tv_usec; /* microseconds */ 
};

比如,如果要計算某代碼運行的時間,可以使用如下代碼:

int main() {

struct timeval tv; 
long long start_time, stop_time, delta_time;

gettimeofday(&tv, NULL); 
start_time= tv.tv_usec;

// your code here

gettimeofday(&tv, NULL); 
stop_time = tv.tv_usec;

delta_time = (stop_time - start_time + 1000000)%1000000; 

}

delta_time就是運行你的代碼運行的時間,單位為毫秒。
值得注意的是,tv_usec的最大值是1000000,即1秒,記到1000000后,又會從0開始,所以這里加上1000000再對1000000取余,解決delta_time為負數的問題。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM