Best Way to Combine Hash Values in C : Demystifying boost::hash_combine
In the world of C , boost::hash_combine is often touted as the optimal method for combining hash values. This begs the question: why is this the best approach?
Understanding boost::hash_combine
The boost::hash_combine function takes two arguments: a seed value and a value to be hashed. It then uses a series of bit manipulations to combine the values, resulting in a new seed that incorporates the entropy of the previous hash.
template <class T> inline void hash_combine(std::size_t& seed, const T& v) { std::hash<T> hasher; seed ^= hasher(v) + 0x9e3779b9 + (seed<<6) + (seed>>2); }
Why is it Not the Best?
Surprisingly, boost::hash_combine is not as optimal as it might seem.
A Better Alternative
An alternative hash combination function can offer both good distribution and entropy preservation:
template <class T> inline size_t hash_combine(std::size_t& seed, const T& v) { return rotl(seed, std::numeric_limits<size_t>::digits/3) ^ distribute(std::hash<T>{}(v)); }
This function utilizes:
Performance Considerations
While boost::hash_combine is fast, the alternative function sacrifices some speed for improved hash quality. However, this speed trade-off is generally negligible for most applications.
The above is the detailed content of Why is boost::hash_combine Not the Best Way to Combine Hash Values in C ?. For more information, please follow other related articles on the PHP Chinese website!