String の Java の hashCode() が乗数として 31 を使用する理由
Java では、String オブジェクトのハッシュ コードは、式:
s[0]*31^(n-1) + s[1]*31^(n-2) + ... + s[n-1]
ここで、s[i] は i 番目の文字です文字列の長さ、n は文字列の長さ、^ はべき乗を示します。
素数乗数の重要性
この式の重要な側面の 1 つは、次の用途です。素数を使用すると、ハッシュ衝突の可能性が減るという利点があります。素数以外の乗数が使用された場合、同じハッシュ値を持つ 2 つの文字列が共通の因数を共有する可能性があり、ハッシュの衝突が発生しやすくなります。
Why Not Another Prime Number?
31 は奇数の素数ですが、29、37、97 など、他の素数も選択できます。
- オーバーフローの回避: 31 は比較的小さい素数であるため、乗算プロセス中の整数オーバーフローのリスクが軽減されます。偶数素数が使用されている場合、2 を乗算するときにオーバーフローが発生し、情報が失われる可能性があります。
- パフォーマンスの最適化: Joshua Bloch が「Effective Java」で述べているように、31 を乗算すると、より効率的なシフトアンド減算演算: 31 * i == (i
- 伝統: ハッシュ関数に素数乗算器を使用することは長年行われており、31 が特によく選ばれています。 31 が特に選ばれた決定的な理由はありませんが、多くのプログラミング言語やアプリケーションで標準的な選択肢となっています。
以上がJava の String hashCode() が乗数として 31 を使用するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

WebStorm Mac版
便利なJavaScript開発ツール

メモ帳++7.3.1
使いやすく無料のコードエディター

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。
