名前空間
変種
操作

std::hash<Key>::operator()

From cppreference.com
< cpp‎ | utility‎ | hash
 
 
ユーティリティライブラリ
言語サポート
型のサポート (基本型、RTTI)
ライブラリ機能検査マクロ (C++20)
プログラムユーティリティ
可変引数関数
コルーチンサポート (C++20)
契約サポート (C++26)
三方比較
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

汎用ユーティリティ
関係演算子 (C++20で非推奨)
 
std::hash
hash::operator()
 

std::hash の特殊化は、以下の条件を満たす operator() を定義する必要があります。

  • Key 型の単一の引数 key を取ること。
  • std::size_t 型の値を返すこと。この値は key のハッシュ値を表します。
  • 等しい2つのパラメータ k1 および k2 に対して、std::hash<Key>()(k1) == std::hash<Key>()(k2) であること。
  • 等しくない2つの異なるパラメータ k1 および k2 に対して、std::hash<Key>()(k1) == std::hash<Key>()(k2) となる確率は、1.0 / std::numeric_limits<size_t>::max() に非常に近い、非常に小さい値であるべきです。

目次

[編集] パラメータ

key - ハッシュする対象のオブジェクト

[編集] 戻り値

ハッシュ値を表す 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
English 日本語 中文(简体) 中文(繁體)