[解決済み] Queueの基本機能を持つ最速のJavaコレクションは何ですか?
2023-07-06 09:22:27
質問
Javaで最も高速なコレクションは何ですか?
私は追加と削除の操作だけが必要で、順序は重要ではありません、等しい要素は問題ではありません、追加と削除以上のものは重要ではありません。
サイズに制限がないことも重要です。
これらのコレクションは、彼の中にオブジェクトを持つことになります。
現在、私はArrayDequeを使用しています。これは、より高速なQueueの実装であることを確認したからです。
どのように解決するのですか?
ArrayDeque
がベストです。参照
このベンチマーク
から来ています。
このブログの記事
で、これをベンチマークした結果について
ArrayDeque
のようなノード割り当てのオーバーヘッドがありません。
LinkedList
のようなノード割り当てのオーバーヘッドもありませんし、 リムーブ時に配列の内容を左にシフトするオーバーヘッドもありません。
ArrayList
が持つオーバーヘッドもありません。ベンチマークでは、約
3x
と同じように
LinkedList
よりも優れており、さらに
ArrayList
よりもわずかに良好です。最高のパフォーマンスを得るためには、おそらく、多くのリサイズを避けるために、一度に保持する可能性のある要素数を保持するのに十分な大きさの初期容量を与えたいと思うことでしょう。
の間に
ArrayList
と
LinkedList
であることから、キューが任意の時間に含む全要素の平均数に依存するようであり、また
LinkedList
を打ちます。
ArrayList
が10要素くらいから始まる。
関連
-
switch case文のcaseの後の列挙定数は列挙型なし
-
WeChat小プログラム Bluetooth通信 Bluetoothモジュールデモ
-
[解決済み] JavaにおけるHashMapとHashtableの違いは何ですか?
-
[解決済み] Javaにおけるpublic、protected、package-private、privateの違いは何ですか?
-
[解決済み] callとapplyの違いは何ですか?
-
[解決済み] Java の配列を表示する最も簡単な方法は何ですか?
-
[解決済み] ファイルの内容からJavaの文字列を作成するにはどうすればよいですか?
-
[解決済み] Javaの「for each」ループはどのように機能するのですか?
-
[解決済み] Javaクラスにおけるcanonical name、simple name、class nameの違いは何ですか?
-
[解決済み] 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 実装 サイバーパンク風ボタン
おすすめ
-
型に解決できない エラー解決
-
SLF4J: クラス・パスに複数のSLF4Jバインディングが含まれています。
-
名前 'XXX' を持つ Bean の作成に失敗しました。自動依存関係の注入に失敗しました 解決方法
-
-bash: java: コマンドが見つからない 解決方法
-
ジャバアレイ
-
API の戻り値を処理するために ResponseEntity を使用する
-
Java基礎編 - オブジェクト指向
-
Server Tomcat v9.0 Server at localhost の起動に失敗しました。
-
コンストラクタDate()が未定義である問題
-
[解決済み】なぜArrayDequeはLinkedListより優れているのか?