[解決済み] なぜhashCodeに素数を使うのですか?
2022-04-13 05:42:27
質問
なぜ、素数がクラスの
hashCode()
メソッドを使用することができますか?例えば、Eclipseを使って私の
hashCode()
メソッドには、常に素数
31
を使用します。
public int hashCode() {
final int prime = 31;
//...
}
参考文献
Hashcodeの良い入門書と、私が見つけたハッシュの仕組みに関する記事です(C#ですが、コンセプトは移植可能です)。 Eric LippertのGetHashCode()のガイドラインとルール
どのように解決するのですか?
掛け合わせる数と入れるバケツの数が直交する素因数分解にしたいからです。
挿入するバケツが8つあるとします。掛け算に使う数字が8の倍数の場合、入れるバケツは最下位(全く掛け算されない方)の項目だけで決まります。似たようなエントリーは衝突してしまいます。ハッシュ関数には向いていません。
31 は十分に大きな素数なので、バケット数がそれで割り切れることはまずありません(実際、最近の java HashMap 実装ではバケット数を 2 のべき乗に抑えています)。
関連
-
Eclipseで "XXXX "の解決策を(型に)解決することができない
-
[解決済み] この2回(1927年)を引き算すると、なぜおかしな結果になるのでしょうか?
-
[解決済み] なぜパスワードにはStringではなくchar[]が好まれるのですか?
-
[解決済み] JavaでArrayListではなくLinkedListを使用するのはいつですか?
-
[解決済み] serialVersionUIDとは何ですか、またなぜそれを使用する必要がありますか?
-
[解決済み] B "の印刷が "#"の印刷より劇的に遅いのはなぜですか?
-
[解決済み] なぜゲッターとセッター/アクセッサーを使うのですか?
-
[解決済み] EqualsメソッドがオーバーライドされたときにGetHashCodeをオーバーライドすることが重要な理由は何ですか?
-
[解決済み】Android UserManager.isUserAGoat()の正しい使用例?)
-
[解決済み】なぜJavaの+=, -=, *=, /=複合代入演算子はキャスティングを必要としないのですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
Methodのinvokeメソッド実装のJavaリフレクション
-
javaでよく使われる英単語
-
スレッド "main" で例外発生 java.net.BindException: アドレスは既に使用中です。NET_Bind
-
SocketTimeoutExceptionの解決方法です。読み込みがタイムアウトした
-
HttpClientがGZIP形式でない場合の対処法
-
[解決済み] Java の String の hashCode() では、なぜ 31 が乗数として使われるのですか?
-
[解決済み] なぜハッシュ関数には素数モジュールが必要なのですか?
-
[解決済み】ビットシフト(bit-shift)演算子とは、どのようなもので、どのように機能するのですか?
-
[解決済み】_hash__()の正しい実装方法と良い方法は?)
-
[解決済み] 2つのキー(キーペア、値)を持つHashMapを作成する方法とは?