命名空间
变体
操作

std::hash<std::optional>

来自 cppreference.com
< cpp‎ | utility‎ | optional
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库特性测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用实用程序
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(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)

 
 
定义在头文件 <optional>
template< class T >
struct hash<std::optional<T>>;
(自 C++17 起)

std::hash 针对 std::optional 类的模板特化允许用户获取 optional 对象中包含的值的哈希值。

如果启用了 std::hash<std::remove_const_t<T>>,则启用特化 std::hash<std::optional<T>> (请参阅 std::hash),否则禁用。

启用后,对于包含值的 std::optional<T> 类型的对象 ostd::hash<std::optional<T>>()(o) 的计算结果与 std::hash<std::remove_const_t<T>>()(*o) 相同。对于不包含值的可选值,哈希值未指定。

此特化的成员函数不保证为 noexcept,因为底层类型的哈希值可能会抛出异常。

[edit] 模板参数

T - optional 对象中包含的值的类型

[edit] 示例

#include <iostream>
#include <optional>
#include <string>
#include <unordered_set>
 
using namespace std::literals;
 
int main()
{
    using OptStr = std::optional<std::string>;
 
    // hash<optional> makes it possible to use unordered_set
    std::unordered_set<OptStr> s =
    {
        "ABC"s, "abc"s, std::nullopt, "def"s
    };
 
    for (const auto& o : s)
        std::cout << o.value_or("(null)") << '\t' << std::hash<OptStr>{}(o) << '\n';
}

可能的输出

def     11697390762615875584
(null)  18446744073709548283
abc     3663726644998027833
ABC     11746482041453314842

[edit] 另请参阅

(C++11)
哈希函数对象
(类模板) [edit]