跳到主要内容

std::hash<std::unique_ptr>

声明

C++11
template<class T, class Deleter> struct hash<unique_ptr<T, Deleter>>;

std::unique_ptr<T, Deleter> 的模板特化 std::hash 允许用户获取 std::unique_ptr<T, Deleter> 类型对象的哈希值。

std::hash<typename std::unique_ptr<T,D>::pointer> enabled 时,特化 std::hash<std::unique_ptr<T,D>> 将被启用(参见 std::hash),否则将被 disabled

enabled 时,对于给定的 std::unique_ptr<T, D> p,此特化确保 std::hash<std::unique_ptr<T, D>>()(p) == std::hash<typename std::unique_ptr<T, D>::pointer>()(p.get())

此特化的成员函数不保证是 noexcept 的,因为指针可能是自定义指针,其哈希值可能会抛出异常。

示例

#include <iostream>
#include <memory>
#include <functional>

struct Foo {
Foo(int nr) { std::cout << "Foo(" << nr << ")\n"; }
~Foo() { std::cout << "~Foo()\n"; }
bool operator==(const Foo &other) { return nr == other.nr; };
int nr;
};

int main()
{
std::cout << std::boolalpha;
Foo* foo = new Foo(5);
std::unique_ptr<Foo> up(foo);

std::cout
<< " hash(up): "
<< std::hash<std::unique_ptr<Foo>>()(up)
<< '\n';
std::cout
<< " hash(foo): "
<< std::hash<Foo*>()(foo)
<< '\n';
std::cout
<< " *up==*foo: "
<< (*up == *foo)
<< '\n';

std::unique_ptr<Foo> other = std::make_unique<Foo>(5);
std::cout
<< " hash(up): "
<< std::hash<std::unique_ptr<Foo>>()(up)
<< '\n';
std::cout
<< " hash(other): "
<< std::hash<std::unique_ptr<Foo>>()(other)
<< '\n';
std::cout
<< " *up==*other: "
<<(*up == *other)
<< '\n';
}
可能结果
Foo(5)
hash(up): 7167008
hash(foo): 7167008
*up==*foo: true
Foo(5)
hash(up): 7167008
hash(other): 7171152
*up==*other: true
~Foo()
~Foo()

std::hash<std::unique_ptr>

声明

C++11
template<class T, class Deleter> struct hash<unique_ptr<T, Deleter>>;

std::unique_ptr<T, Deleter> 的模板特化 std::hash 允许用户获取 std::unique_ptr<T, Deleter> 类型对象的哈希值。

std::hash<typename std::unique_ptr<T,D>::pointer> enabled 时,特化 std::hash<std::unique_ptr<T,D>> 将被启用(参见 std::hash),否则将被 disabled

enabled 时,对于给定的 std::unique_ptr<T, D> p,此特化确保 std::hash<std::unique_ptr<T, D>>()(p) == std::hash<typename std::unique_ptr<T, D>::pointer>()(p.get())

此特化的成员函数不保证是 noexcept 的,因为指针可能是自定义指针,其哈希值可能会抛出异常。

示例

#include <iostream>
#include <memory>
#include <functional>

struct Foo {
Foo(int nr) { std::cout << "Foo(" << nr << ")\n"; }
~Foo() { std::cout << "~Foo()\n"; }
bool operator==(const Foo &other) { return nr == other.nr; };
int nr;
};

int main()
{
std::cout << std::boolalpha;
Foo* foo = new Foo(5);
std::unique_ptr<Foo> up(foo);

std::cout
<< " hash(up): "
<< std::hash<std::unique_ptr<Foo>>()(up)
<< '\n';
std::cout
<< " hash(foo): "
<< std::hash<Foo*>()(foo)
<< '\n';
std::cout
<< " *up==*foo: "
<< (*up == *foo)
<< '\n';

std::unique_ptr<Foo> other = std::make_unique<Foo>(5);
std::cout
<< " hash(up): "
<< std::hash<std::unique_ptr<Foo>>()(up)
<< '\n';
std::cout
<< " hash(other): "
<< std::hash<std::unique_ptr<Foo>>()(other)
<< '\n';
std::cout
<< " *up==*other: "
<<(*up == *other)
<< '\n';
}
可能结果
Foo(5)
hash(up): 7167008
hash(foo): 7167008
*up==*foo: true
Foo(5)
hash(up): 7167008
hash(other): 7171152
*up==*other: true
~Foo()
~Foo()