ホームページ > Java > &#&チュートリアル > リストから要素を削除すると UnsupportedOperationException がスローされるのはなぜですか?

リストから要素を削除すると UnsupportedOperationException がスローされるのはなぜですか?

Susan Sarandon
リリース: 2024-12-30 21:51:10
オリジナル
512 人が閲覧しました

Why Does Removing Elements from a List Throw an UnsupportedOperationException?

UnsupportedOperationException: リストからの要素の削除

list.remove(index) を使用してリストから要素を削除しようとすると、 UnsupportedOperationException が発生しました。このエラーは、Arrays.asList() によって返される固定サイズのリストの使用に起因します。

Arrays.asList() は固定サイズのリストを返します

Arrays .asList() は、指定された配列を基にしたリストを作成します。このリストは不変であり、要素の追加や削除などの構造の変更はサポートされていません。

修正:

この問題を解決するには、削除を許可する可変リストの実装を使用します。たとえば、LinkedList を使用できます。

List<String> list = new LinkedList<>(Arrays.asList(split));
ログイン後にコピー

正規表現による分割

split() メソッドは、文字列を分割するために正規表現とともに使用されます。パイプ文字 (|) は正規表現のメタ文字であり、リテラルとして使用する場合はエスケープする必要があります。

修正:

リテラルのパイプ文字で分割するには、エスケープします。二重バックスラッシュを使用します。

template.split("\|")
ログイン後にコピー

最適化アルゴリズム

remove() を繰り返し呼び出す代わりに、より効率的なアルゴリズムを検討してください。

  1. 0 から list.size() までの範囲内の数値のランダムな配列を生成します。 - 1.
  2. 数値を昇順に並べ替えます。
  3. 作成別のリストを作成し、ソートされた数値を反復しながらリストを反復します。
  4. ソートされたリスト内の現在の数値のインデックスがリスト内の要素のインデックスと一致する場合、リストに対してremove()を呼び出し、要素を削除します。

このアルゴリズムは O(N) 時間で実行されます。N はリストのサイズであり、元のアプローチよりも大幅に高速です。

以上がリストから要素を削除すると UnsupportedOperationException がスローされるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート