名前空間
変種
操作

std::hash <std::unique_ptr>

提供: cppreference.com
< cpp‎ | memory‎ | unique ptr
 
 
ユーティリティライブラリ
汎用ユーティリティ
日付と時間
関数オブジェクト
書式化ライブラリ(C++20)
(C++11)
関係演算子 (C++20で非推奨)
整数比較関数
(C++20)
スワップと型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
一般的な語彙の型
(C++11)
(C++17)
(C++17)
(C++17)
(C++17)

初等文字列変換
(C++17)
(C++17)
 
動的メモリ管理
未初期化記憶域
ガベージコレクションサポート
その他
(C++20)
(C++11)
(C++11)
C のライブラリ
低水準のメモリ管理
 
 
template<class T, class Deleter>struct hash<unique_ptr<T, Deleter>>;
(C++11以上)

std::unique_ptr<T, Deleter> に対する std::hash のテンプレート特殊化は、 std::unique_ptr<T, Deleter> 型オブジェクトのハッシュの取得を可能とします。

std::hash<std::unique_ptr<T,D>> の特殊化は、 std::hash<typename std::unique_ptr<T,D>::pointer> が有効化 (std::hash を参照) されていれば有効化され、そうでなければ無効化されます。

(C++17以上)

有効化されていれば、(C++17以上) 何らかの std::unique_ptr<T, D> p に対して、この特殊化は std::hash<std::unique_ptr<T, D>>()(p)==std::hash<typenamestd::unique_ptr<T, D>::pointer>()(p.get()) であることを保証します。

ポインタがファンシーポインタで、そのハッシュが例外を投げるかもしれないため、この特殊化のメンバ関数は noexcept であることを保証しません。

[編集]

#include <iostream>#include <memory>#include <functional>   struct Foo { Foo(){std::cout<<"Foo...\n";} ~Foo(){std::cout<<"~Foo...\n\n";}};   int main(){ Foo* foo = new Foo();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';}

出力:

Foo... hash(up): 3686401041 hash(foo): 3686401041 ~Foo...

[編集]関連項目

(C++11)
ハッシュ関数オブジェクト
(クラステンプレート)[edit]
close