std::hash<std::optional>
来自 cppreference.com
定义在头文件 <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> 类型的对象 o
,std::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) |
哈希函数对象 (类模板) |