ホームページ Java &#&はじめる ArrayList、LinkedList、Vector の違いは何ですか?

ArrayList、LinkedList、Vector の違いは何ですか?

Aug 06, 2020 pm 04:01 PM
arraylist linkedlist vector

ArrayList、LinkedList、Vector の違いは何ですか?

#1. ストレージのデータ構造からの分析

(推奨チュートリアル:

Java 入門チュートリアル)

ArrayList: Array

Vector: Array

LinkedList: 二重リンク リスト

Array: 添字に基づいてすばやく検索できるため、ほとんどの場合、クエリは次のようになります。速い。

ただし、追加および削除操作を実行する場合は、すべての要素を変更された要素の後ろに移動する必要があるため、追加および削除のオーバーヘッドが比較的大きく、配列の追加および削除の実行効率が低下します。削除操作は少ないです。データの格納構造として配列を使用する ArrayList や Vector も同様の特徴を持ち、クエリ速度は速い(添え字に基づいて直接取得できるため反復検索より速い)、追加や削除は遅いです。

リンクリスト: ノード間の参照を扱うだけで要素の追加や削除ができるので便利です。並んで手をつなぐのと同じように、誰かを追加・削除したい場合も、近くにいる2人を別の人に変更するだけで、すでに手をつなぐ人には影響しません。代替によって消費されるリソースと時間はどこでも同じです。

しかし、クエリは不便で、1つずつ比較する必要があり、添え字に基づいて直接検索することはできません。リンク リスト構造で格納される LinkedList にもこれらの特性があり、追加と削除は簡単ですが、クエリが遅くなります (シーケンシャル クエリではなく、ランダム クエリを指します)。

2. 継承の観点からの分析

ArrayList、LinkedList、Vector の違いは何ですか?

これらはすべて List インターフェイスを実装しています。つまり、すべて get(int を実装しています) location )、remove(int location) などの「インデックス値に基づいてノードを取得および削除する関数」。

(ビデオチュートリアルの推奨:

java ビデオチュートリアル)

添字に従って配列構造の値を取得するのは簡単で、双方向の LinkedList の実装も可能です。 list もインデックス値をカウントする比較的単純な実装です 実装する場合は、連結リストの長さの 1/2 から検索を開始します 添字が大きい場合はリストの先頭から検索を開始します 添字が小さい場合はリストの先頭から検索しますリストの最後から検索を開始します。

3. 同時実行安全性の観点からの分析

Vector: スレッド セーフティ

ArrayList: 非スレッド セーフティ

LinkedList : 非スレッド セキュリティ

4. データ増加分析

ベクトル: デフォルトでは、増加は元の配列の長さの 2 倍になります。デフォルトについて言えば、実際には初期化サイズを個別に設定できることを意味します。

ArrayList: 元の配列の 50% を自動的に拡大します。

以上がArrayList、LinkedList、Vector の違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Java ArrayList を走査するときに要素を削除するために foreach と iterator を使用することの違いは何ですか? Java ArrayList を走査するときに要素を削除するために foreach と iterator を使用することの違いは何ですか? Apr 27, 2023 pm 03:40 PM

1. Iterator と foreach の違いはポリモーフィックな違いです (foreach の最下層は Iterator です) Iterator はインターフェイス型であり、コレクションや配列の型を気にしません; for と foreach の両方がコレクションの型を知る必要がありますまず、コレクション内の要素の種類についても; 1. foreach の最下層はイテレータによって記述されたコードであると言われる理由: 逆コンパイルされたコード: 2. foreach の削除とイテレータの違い まず、Alibaba を見てください。 Java 開発マニュアル。ただし、ケース 1 ではエラーは報告されず、ケース 2 (java.util.ConcurrentModificationException) では最初にエラーが報告されます。

JavaでArrayListに特定の要素が含まれているかどうかを確認するにはどうすればよいですか? JavaでArrayListに特定の要素が含まれているかどうかを確認するにはどうすればよいですか? Sep 03, 2023 pm 04:09 PM

List インターフェイスの contains() メソッドを使用して、リストにオブジェクトが存在するかどうかを確認できます。 contains() メソッド booleancontains(Objecto) このリストに指定された要素が含まれる場合、true を返します。より正式には、このリストに (o==null?e==null:o.equals(e)) のような要素 e が少なくとも 1 つ含まれる場合にのみ true を返します。パラメータ c - このリスト内の存在がテストされる要素。戻り値 このリストに指定された要素が含まれている場合は true を返します。 ClassCastException をスローします - 指定された要素の型がこのリストと互換性がない場合 (オプション)。 NullP

JavaのArrayList.remove()関数を使用してArrayListから要素を削除します。 JavaのArrayList.remove()関数を使用してArrayListから要素を削除します。 Jul 24, 2023 pm 01:21 PM

Java の ArrayList.remove() 関数を使用して、ArrayList から要素を削除します。Java では、ArrayList は、要素のセットを保存および操作するためによく使用されるコレクション クラスです。 ArrayList クラスは、コレクション内の要素を追加、削除、変更、クエリするためのメソッドを多数提供します。より頻繁に使用されるメソッドの 1 つは、ArrayList から要素を削除できる Remove() です。 ArrayList のremove() メソッドには 2 つのオーバーロード形式があります。

LinkedList クラスのremoveLast() メソッドを使用して、リンク リストの最後の要素を削除します。 LinkedList クラスのremoveLast() メソッドを使用して、リンク リストの最後の要素を削除します。 Jul 24, 2023 pm 05:13 PM

リンク リストの最後の要素を削除するには、LinkedList クラスの RemoveLast() メソッドを使用します。LinkedList は、Java コレクション フレームワークの一般的なデータ構造です。要素は二重リンク リストの形式で格納されます。 LinkedList クラスが提供するメソッドを使用すると、要素の追加、削除、変更など、リンク リストを簡単に操作できます。シナリオによっては、リンクされたリストの最後の要素を削除する必要がある場合があります。 LinkedList クラスは、removeLas を提供します

Java の ArrayList の初期容量が 10 である理由は何ですか? Java の ArrayList の初期容量が 10 である理由は何ですか? May 10, 2023 pm 02:19 PM

HashMap の初期容量が 16 なのはなぜですか? ArrayList の初期化能力について話すときは、まず HashMap の初期化能力を確認する必要があります。 Java8 ソース コードを例にとると、HashMap には初期化容量と負荷係数という 2 つの関連要素があります。 /***Thedefaultinitialcapacity-MUSTbeapoweroftwo.*/staticfinalintDEFAULT_INITIAL_CAPACITY=1>1);if(newCapacity-minCapacity0)newCapacity=hugeCapacity

Java の ArrayList.clear() 関数を使用して、ArrayList 内の要素をクリアします。 Java の ArrayList.clear() 関数を使用して、ArrayList 内の要素をクリアします。 Jul 24, 2023 pm 02:04 PM

Java の ArrayList.clear() 関数を使用して、ArrayList 内の要素をクリアします。Java プログラミングでは、ArrayList は、要素を動的に保存およびアクセスできる非常に一般的に使用されるデータ構造です。ただし、場合によっては、メモリを再利用または解放するために、ArrayList 内のすべての要素をクリアする必要がある場合があります。このとき、ArrayList の clear() 関数を使用してこれを実現できます。 ArrayList.clear()

Java は、ArrayList クラスの contains() 関数を使用して、要素が存在するかどうかを判断します。 Java は、ArrayList クラスの contains() 関数を使用して、要素が存在するかどうかを判断します。 Jul 24, 2023 pm 07:33 PM

Java は、ArrayList クラスの contains() 関数を使用して、要素が存在するかどうかを判断します。ArrayList は、Java プログラミングで非常に一般的に使用されるデータ構造です。これは、一連のデータを保存および操作するための柔軟な方法を提供します。 ArrayList は、単純に要素を追加、削除、アクセスするだけでなく、要素が ArrayList に存在するかどうかを判断するために使用される contains() 関数など、いくつかの便利なメソッドも提供します。 contains() 関数は A

LinkedList に要素を追加する Java プログラム LinkedList に要素を追加する Java プログラム Aug 26, 2023 pm 10:21 PM

LinkedList は JavaCollectionFramework の一般クラスで、List、Deque、Queue の 3 つのインターフェイスを実装します。これは、各要素が相互にリンクされている線形データ構造である LinkedList データ構造の機能を提供します。 LinkedList に対して、要素の追加、削除、走査などのさまざまな操作を実行できます。 LinkedList コレクションに要素を追加するには、add()、addFirst()、addLast() などのさまざまな組み込みメソッドを使用できます。これらのメソッドを使用して要素を LinkedList に追加する方法を検討します。 Javaで

See all articles