std::hash<std::chrono::time_point>
来自cppreference.com
< cpp | chrono | time point
在标头 <chrono> 定义
|
||
template< class Clock, class Duration > struct hash<std::chrono::time_point<Clock, Duration>>; |
(C++26 起) | |
std::hash 对 std::chrono::time_point 的模板特化允许用户获得 std::chrono::time_point<Clock, Duration> 对象的散列值。此特化只有在 std::hash<Clock> 和 std::hash<Duration> 都启用时才会启用。
注解
功能特性测试宏 | 值 | 标准 | 注释 |
---|---|---|---|
__cpp_lib_chrono |
202306L | (C++26) | std::chrono 值类的散列支持
|
示例
运行此代码
#include <chrono> #include <cstddef> #include <iostream> #include <string> #include <thread> #include <unordered_map> using system_clock_tp = std::chrono::time_point<std::chrono::system_clock>; #if __cpp_lib_chrono < 202306L // std::hash 的自定义特化可以注入命名空间 std template<> struct std::hash<system_clock_tp> { std::size_t operator()(const system_clock_tp& d) const noexcept { return d.time_since_epoch().count(); } }; #endif int main() { using namespace std::chrono_literals; std::unordered_map<system_clock_tp, std::string> log; for (int i{}; i != 4; ++i) { std::this_thread::sleep_for(100ms); log[std::chrono::system_clock::now()] = "事件 #" + std::to_string(i); } for (auto const& [time, message] : log) std::cout << "[" << time << "],消息:" << message << '\n'; }
可能的输出:
[2023-08-31 21:42:26.100842469],消息:事件 #3 [2023-08-31 21:42:26.000441887],消息:事件 #2 [2023-08-31 21:42:25.900354894],消息:事件 #1 [2023-08-31 21:42:25.800025900],消息:事件 #0
参阅
(C++11) |
散列函数对象 (类模板) |