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為負數的問題。