Fungsi Rangsangan::hash_combine telah dipuji sebagai kaedah yang cekap untuk menggabungkan nilai cincang. Walau bagaimanapun, kelebihannya melangkaui hanya kelajuan; ia juga menyediakan percampuran dan pemeliharaan entropi yang dipertingkatkan.
Fungsi, seperti yang dipamerkan dalam coretan kod di bawah, menggunakan gabungan fungsi cincang dalaman, xor-shifts , dan nombor ajaib (0x9e3779b9):
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); }
Walaupun penggunaannya meluas, pelaksanaan asal boost::hash_combine tidak optimum dari segi pengedaran. Apabila digunakan bersama dengan fungsi cincang pengedaran yang kurang baik seperti std::cincang, ia boleh menyebabkan bilangan perlanggaran yang tinggi.
Sementara rangsangan yang disemak:: hash_combine dalam versi 1.81 menangani isu pengedaran ini, mari kita teroka pendekatan alternatif yang menawarkan pengadunan dan pemeliharaan entropi yang luar biasa:
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)); }
Algoritma yang diubah suai ini menggunakan berbilang anjakan xor dan operasi putaran untuk mencapai pencampuran yang unggul, menghasilkan cincangan teragih lebih sekata.
Walaupun boost::hash_combine kekal sebagai pilihan pantas, algoritma alternatif yang disemak menyediakan pencampuran dan pemeliharaan entropi yang dipertingkatkan dengan melaksanakan berbilang anjakan-x dan operasi putaran. Untuk aplikasi yang memerlukan pencincangan yang meluas, bilangan perlanggaran yang berkurangan dan pengedaran yang lebih baik menjadikannya pilihan yang lebih dipercayai.
Atas ialah kandungan terperinci Adakah boost::hash_combine Penyelesaian Ideal untuk Menggabungkan Nilai Hash?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!