首頁 >後端開發 >C++ >如何從 `std::chrono::time_point` 物件中提取時間分量?

如何從 `std::chrono::time_point` 物件中提取時間分量?

Susan Sarandon
Susan Sarandon原創
2024-11-02 18:58:31471瀏覽

How can I extract temporal components from a `std::chrono::time_point` object?

從std::chrono::time_point 提取時間分量

目標:取得年、月、日、時、分、秒,以及來自std::chrono::time_point 物件的毫秒。

解決方案:

要提取此信息,您特別需要一個 system_clock::time_point,提供與民用日曆系統的關係。

<code class="cpp">using namespace std::chrono;
system_clock::time_point now = system_clock::now();</code>

下一步是將其轉換為time_t,使用:

<code class="cpp">time_t tt = system_clock::to_time_t(now);</code>

利用C 庫將time_t 轉換為tm,確保正確的時間選擇區域:

<code class="cpp">tm utc_tm = *gmtime(&amp;tt);
tm local_tm = *localtime(&amp;tt);</code>

現在,您可以提取tm 的組件:

<code class="cpp">std::cout << local_tm.tm_year + 1900 << '\n';
std::cout << local_tm.tm_mon + 1 << '\n';
std::cout << local_tm.tm_mday << '\n';

提取系統時鐘組件

此外,如果您願意,您可以可以依賴以下非保證方法:

大多數人所知的system_clock 的每個實作都是基於Unix 時間(自1970 年1 月1 日UTC 以來的秒數),通常具有比秒更精細的精度。

以下綜合程序提供了提取所有時間分量的範例:

<code class="cpp">#include <chrono>
#include <ctime>
#include <iostream>

int main() {
  using namespace std::chrono;
  typedef duration<int, ratio_multiply<hours::period, ratio<24> >::type> days;
  system_clock::time_point now = system_clock::now();
  system_clock::duration tp = now.time_since_epoch();
  days d = duration_cast<days>(tp);
  tp -= d;
  hours h = duration_cast<hours>(tp);
  tp -= h;
  minutes m = duration_cast<minutes>(tp);
  tp -= m;
  seconds s = duration_cast<seconds>(tp);
  tp -= s;
  std::cout << d.count() << "d " << h.count() << ':' << m.count() << ':' << s.count();
  std::cout << " " << tp.count() << "[" << system_clock::duration::period::num << '/' << system_clock::duration::period::den << "]\n";

  time_t tt = system_clock::to_time_t(now);
  tm utc_tm = *gmtime(&amp;tt);
  tm local_tm = *localtime(&amp;tt);
  std::cout << utc_tm.tm_year + 1900 <&lt '-';
  std::cout << utc_tm.tm_mon + 1 << '-';
  std::cout << utc_tm.tm_mday << ' ';
  std::cout << utc_tm.tm_hour << ':';
  std::cout << utc_tm.tm_min << ':';
  std::cout << utc_tm.tm_sec << '\n';
}</code>

使用自訂持續時間

要對天進行建模,請建立自訂持續時間:

<code class="cpp">typedef duration<int, ratio_multiply<hours::period, ratio<24> >::type> days;</code>

現在您可以使用system_clock::duration 的精度獲取自紀元以來的時間:

<code class="cpp">system_clock::duration tp = now.time_since_epoch();</code>

將其截斷為天並減去:

<code class="cpp">days d = duration_cast<days>(tp);
tp -= d;</code>

重複此操作處理小時、分鐘和秒。

餘數是以 system_clock::duration 為單位的秒的一小部分。

使用日期庫

此C 11/14 庫簡化了上述過程:

<code class="cpp">#include "date.h"
#include <iostream>

int main() {
  using C = std::chrono;
  using D = date;
  using S = std;

  auto tp = C::system_clock::now();
  {
    using namespace date;
    S::cout << tp << '\n';
  }
  auto dp = D::floor<D::days>(tp);
  auto ymd = D::year_month_day{dp};
  auto time = D::make_time(C::duration_cast<C::milliseconds>(tp - dp));
  S::cout << "year        = " << ymd.year() << '\n';
  S::cout << "month       = " << ymd.month() << '\n';
  S::cout << "day         = " << ymd.day() << '\n';
  S::cout << "hour        = " << time.hours().count() << "h\n";
  S::cout << "minute      = " << time.minutes().count() << "min\n";
  S::cout << "second      = " << time.seconds().count() << "s\n";
  S::cout << "millisecond = " << time.subseconds().count() << "ms\n";
}

C 20 標準庫支援

C 20 引入了用於從system_clock::time_point 中提取這些欄位的標準化語法:

<code class="cpp">#include <chrono>

int main() {
  using namespace std::chrono;
  auto tp = system_clock::now();
  auto dp = floor<days>(tp);
  year_month_day ymd{dp};
  hh_mm_ss time{floor<milliseconds>(tp - dp)};
  auto y = ymd.year();
  auto m = ymd.month();
  auto d = ymd.day();
  auto h = time.hours();
  auto M = time.minutes();
  auto s = time.seconds();
  auto ms = time.subseconds();
}</code>

以上是如何從 `std::chrono::time_point` 物件中提取時間分量?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn