首页 >后端开发 >C++ >如何从 `std::chrono::time_point` 对象中提取时间分量?

如何从 `std::chrono::time_point` 对象中提取时间分量?

Susan Sarandon
Susan Sarandon原创
2024-11-02 18:58:31469浏览

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