為了利用使用者定義的型別作為無序容器(例如std::unordered_set 和std: :)中的鍵unordered_map,需要實作相等運算子(運算子==)和雜湊函子。更方便的方法是專門為自訂類型建立一個預設雜湊函數,類似於為標準類型提供的內建雜湊函數。
檢查各種資源後,似乎專門針對 std::hash< ;X>::operator() 對於使用者定義類型 X 確實是可行的。但是,出現了以下問題:
C 標準明確允許並鼓勵向 std 命名空間添加專門化,前提是所涉及的類型之一是用戶定義的。因此,第一個問題可以肯定地回答。
在C 11 中特化雜湊函數的正確且首選的方法是在std 命名空間中定義一個結構體,如下所示:
namespace std { template <> struct hash<Foo> { size_t operator()(const Foo & x) const { // Implementation of the hash function for type Foo } }; }
此語法確保符合C 11標準,並允許為使用者定義的自訂雜湊函數規範types.
不幸的是,C 中沒有獨立於平台的方法來專門化std::hash
以上是如何在 C 無序容器中擴展自訂類型的標準雜湊函數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!