バックグラウンド
実際の作業では、マルチスレッド操作 Collections.sort が発生し、ConcurrentModificationException が発生しました。これは、複数のスレッドが同じ共有変数を操作することが原因で発生します。
ソリューションはロックできます。
package com.test.wyf.springprofile;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class MultiThreadCollectionsSort {
public static void main(String[] args) {
System.out.println("main start......");
List<String> list = new ArrayList<>();
list.add("one");
list.add("two");
list.add("three");
for (int i = 0; i < 3; i++) {
new Thread(() -> {
Collections.sort(list);
System.out.println("thread done...");
}).start();
}
System.out.println("main done......");
}
}
時々エラーが報告される
main start......
main done......
thread done...
Exception in thread "Thread-1" Exception in thread "Thread-2" java.util.ConcurrentModificationException
at java.util.ArrayList.sort(ArrayList.java:1466)
at java.util.Collections.sort(Collections.java:143)
at com.test.wyf.springprofile.MultiThreadCollectionsSort.lambda$main$0(MultiThreadCollectionsSort.java:18)
at java.lang.Thread.run(Thread.java:748)
java.util.ConcurrentModificationException
at java.util.ArrayList.sort(ArrayList.java:1466)
at java.util.Collections.sort(Collections.java:143)
at com.test.wyf.springprofile.MultiThreadCollectionsSort.lambda$main$0(MultiThreadCollectionsSort.java:18)
at java.lang.Thread.run(Thread.java:748)
エラーが報告されない場合もあります (何度も試してみると、まれに次のように表示されることがあります)。
main start......
main done......
thread done...
thread done...
thread done...
コードを改善し、リスト オブジェクトをロック オブジェクトとして使用できるようにしました。
public static void main(String[] args) {
System.out.println("main start......");
List<String> list = new ArrayList<>();
list.add("one");
list.add("two");
list.add("three");
for (int i = 0; i < 3; i++) {
new Thread(() -> {
synchronized (list) {
Collections.sort(list);
}
System.out.println("thread done...");
}).start();
}
System.out.println("main done......");
}