std::hash<std::chrono::time_point>

来自cppreference.com
< cpp‎ | chrono‎ | time point
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)
 
 
 
在标头 <chrono> 定义
template< class Clock, class Duration >
struct hash<std::chrono::time_point<Clock, Duration>>;
(C++26 起)

std::hashstd::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)
散列函数对象
(类模板)