命名空间
变体
操作

std::chrono::get_tzdb_list, std::chrono::get_tzdb, std::chrono::remote_version, std::chrono::reload_tzdb

来自 cppreference.cn
< cpp‎ | chrono
 
 
日期和时间库
时间点
(C++11)
(C++20)
时长
(C++11)
时钟
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
一天中的时间
(C++20)(C++20)
(C++20)(C++20)
(C++20)
日历
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)(C++20)
chrono I/O
(C++20)

时区
(C++20)
(C++20)
get_tzdbget_tzdb_listreload_tzdbremote_version
(C++20)(C++20)(C++20)(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
C 风格日期和时间
 
std::chrono::tzdb_list& get_tzdb_list();
(1) (since C++20)
const std::chrono::tzdb& get_tzdb();
(2) (since C++20)
std::string remote_version();
(3) (since C++20)
const std::chrono::tzdb& reload_tzdb();
(4) (since C++20)

这些函数提供对程序范围时区数据库的访问。

1) 返回对全局 std::chrono::tzdb_list 单例的引用。如果这是首次访问数据库,则初始化数据库。初始化后,数据库将包含一个已初始化的 std::chrono::tzdb 对象。此函数是线程安全的:从多个线程并发调用此函数不会引入数据竞争。
2) 返回对 `tzdb_list` 单例持有的第一个 std::chrono::tzdb 对象的引用。等价于 std::chrono::get_tzdb_list().front()
3) 返回一个包含最新远程数据库版本的字符串。
4) 如果 remote_version() != get_tzdb().version,则将表示远程数据库的新 tzdb 对象推送到 get_tzdb_list() 引用的 tzdb_list 单例的前端。否则,没有效果。引用、指针或迭代器均不会失效。并发调用此函数与 get_tzdb_list().front()get_tzdb_list().erase_after() 不会引入数据竞争。

[编辑] 异常

1) std::runtime_error 如果由于任何原因无法返回对包含一个或多个有效 tzdbtzdb_list 的引用。

[编辑] 返回值

1) 对全局 std::chrono::tzdb_list 单例的引用。
2) std::chrono::get_tzdb_list().front()
3) 一个包含最新远程数据库版本的字符串。
4) std::chrono::get_tzdb_list().front()(在此函数进行任何更新之后)。