Namespaces
Variants

std:: hash <std::unique_ptr>

From cppreference.net
Memory management library
( exposition only* )
Allocators
Uninitialized memory algorithms
Constrained uninitialized memory algorithms
Memory resources
Uninitialized storage (until C++20)
( until C++20* )
( until C++20* )
( until C++20* )

Garbage collector support (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
template < class T, class Deleter >
struct hash < std:: 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 <functional>
#include <iostream>
#include <memory>
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'
              << "hash(foo):   " << std::hash<Foo*>()(foo) << '\n'
              << "*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'
              << "hash(other): " << std::hash<std::unique_ptr<Foo>>()(other) << '\n'
              << "*up==*other: " <<(*up == *other) << "\n\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)
функциональный объект хеш-функции
(шаблон класса)