首頁 > 後端開發 > C++ > 為什麼「time()」有時在短任務之前和之後返回相同的值?

為什麼「time()」有時在短任務之前和之後返回相同的值?

Susan Sarandon
發布: 2025-01-03 15:07:40
原創
303 人瀏覽過

Why Does `time()` Sometimes Return the Same Value Before and After a Short Task?

輕鬆測量經過的時間

問題:

使用以下命令測量程序中的時間time(),為什麼之前和之後的值可能還是相同?

解釋:

time() 返回自紀元以來的當前時間(以秒為單位)。如果要測量的時間跨度很短,前後值之間的差異可能會太小而無法偵測到。

解:

要準確測量短時間時間跨度,考慮使用替代方法:

C 結構化時間測量:

struct timeval startTV, endTV;
gettimeofday(&startTV, NULL); 
// Execute time-consuming tasks
gettimeofday(&endTV, NULL); 

timersub(&endTV, &startTV, &diff);
printf("**time taken = %ld %ld\n", diff.tv_sec, diff.tv_usec);
登入後複製
  • timeval結構表示精確到微秒的時間值。
  • gettimeofday() 取得一天中的當前時間。
  • timersub() 計算兩個 timeval 結構之間的差異。
  • 結果以秒為單位報告(diff.tv_sec) 和微秒 (diff.tv_usec)。

C 11 風格精確時間測量:

#include <chrono>

std::chrono::steady_clock::time_point begin = std::chrono::steady_clock::now();
// Execute time-consuming tasks
std::chrono::steady_clock::time_point end = std::chrono::steady_clock::now();

std::cout << "Time difference = " << std::chrono::duration_cast<std::chrono::microseconds>(end - begin).count() << "[µs]" << std::endl;
std::cout << "Time difference = " << std::chrono::duration_cast<std::chrono::nanoseconds>(end - begin).count() << "[ns]" << std::endl;
登入後複製
  • std:: chrono庫提供高精度時間
  • d ::chrono::steady_clock 測量自未知任意時間點以來的時間。
  • 時間差計算為 std::chrono::duration 對象,可以是轉換為微秒或奈秒。

以上是為什麼「time()」有時在短任務之前和之後返回相同的值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板