std:: hash<Key>:: operator()
From cppreference.net
C++
Utilities library
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
std::hash
|
hash::operator()
|
Специализации
std::hash
должны определять
operator()
, который:
-
Принимает единственный аргумент
key
типа
Key. - Возвращает значение типа std:: size_t , представляющее хеш-значение key .
-
Для двух параметров
k1иk2, которые равны, std:: hash < Key > ( ) ( k1 ) == std:: hash < Key > ( ) ( k2 ) . -
Для двух различных параметров
k1иk2, которые не равны, вероятность того, что std:: hash < Key > ( ) ( k1 ) == std:: hash < Key > ( ) ( k2 ) , должна быть очень мала, приближаясь к 1.0 / std:: numeric_limits < size_t > :: max ( ) .
Содержание |
Параметры
| key | - | объект для хеширования |
Возвращаемое значение
A std:: size_t представляющий хеш-значение.
Исключения
Хеш-функции не должны генерировать исключения.
Пример
Следующий код показывает, как специализировать шаблон std::hash для пользовательского класса. Хеш-функция использует алгоритм хеширования Fowler–Noll–Vo .
Запустить этот код
#include <cstdint> #include <functional> #include <iostream> #include <string> struct Employee { std::string name; std::uint64_t ID; }; namespace std { template <> class hash<Employee> { public: std::uint64_t operator()(const Employee& employee) const { // computes the hash of an employee using a variant // of the Fowler-Noll-Vo hash function constexpr std::uint64_t prime{0x100000001B3}; std::uint64_t result{0xcbf29ce484222325}; for (std::uint64_t i{}, ie = employee.name.size(); i != ie; ++i) result = (result * prime) ^ employee.name[i]; return result ^ (employee.ID << 1); } }; } int main() { Employee employee; employee.name = "Zaphod Beeblebrox"; employee.ID = 42; std::hash<Employee> hash_fn; std::cout << hash_fn(employee) << '\n'; }
Вывод:
12615575401975788567