實際上,我學習收藏和例外,我不明白爲什麼這個工程:雖然Collections.shuffle()不會拋出ConcurrentModificationException
List<Integer> intList = new ArrayList<Integer>(Arrays.asList(1,2,3,4,5,6,7,8,9,10));
for (Integer s : intList) {
Collections.shuffle(intList);
System.out.println(s);
}
閱讀該文檔,它指出
當這樣的修改不被允許時,這種異常可能會被檢測到併發修改對象的方法拋出。
綜觀集合源代碼:
public static void shuffle(List<?> list) {
if (r == null) {
r = new Random();
}
shuffle(list, r);
}
所以我來看看隨機播放功能:
public static void shuffle(List<?> list, Random rnd) {
int size = list.size();
if (size < SHUFFLE_THRESHOLD || list instanceof RandomAccess) {
for (int i=size; i>1; i--)
swap(list, i-1, rnd.nextInt(i));
} else {
Object arr[] = list.toArray();
// Shuffle array
for (int i=size; i>1; i--)
swap(arr, i-1, rnd.nextInt(i));
// Dump array back into list
ListIterator it = list.listIterator();
for (int i=0; i<arr.length; i++) {
it.next();
it.set(arr[i]);
}
}
}
最後,調用交換功能:
public static void swap(List<?> list, int i, int j) {
final List l = list;
l.set(i, l.set(j, l.get(i)));
}
這不會修改當前列表,而itera (或這是因爲這條線final List l = list;
)?我想我錯過了一些重要的東西。
我想在這裏修改意味着添加(或)刪除哪些改變列表的大小,而不是交換。 – kosa
它可能是特定於實現的,但'set'通常不會更改運行整個ConcurrentModificationException的'modCount' show .. –