std::hash<std::unique_ptr>
Материал из cppreference.com
<tbody>
</tbody>
template<class T, class Deleter> struct hash<unique_ptr<T, Deleter>>; |
(начиная с C++11) | |
Специализация шаблона std::hash для std::unique_ptr<T, Deleter> позволяет пользователям получать хэши объектов типа std::unique_ptr<T, Deleter>.
Специализация std::hash<std::unique_ptr<T,D>> доступна (смотрите std::hash), если доступен std::hash<typename std::unique_ptr<T,D>::pointer>, иначе не доступна.
Когда доступна для данного 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 num) : nr(num) { std::cout << "Foo(" << nr << ")\n"; }
~Foo() { std::cout << "~Foo()\n"; }
bool operator==(const Foo &other) const { return nr == other.nr; };
int nr;
};
int main()
{
std::cout << std::boolalpha << std::hex;
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\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): acac20
hash(foo): acac20
*up==*foo: true
Foo(5)
hash(up): acac20
hash(other): acbc50
*up==*other: true
~Foo()
~Foo()
Смотрите также
(C++11) |
Объект хеш-функции (шаблон класса) |