JAVA Collections.shuffle打乱列表

在JAVA中如果想打乱LIST的顺序可以调用Collections.shuffle()或者Collections.shuffle(List<?> list, Random rnd)方法。

Random rand = new Random();
Integer[] ia = {1,2,3,4,5,6,7,8,9,10};
List<Integer> list1 = new ArrayList<Integer>(Arrays.asList(ia));
System.out.println("list1打乱前的顺序:"+list1.toString());
Collections.shuffle(list1,rand);
System.out.println("list1打乱后的顺序:"+list1.toString());
System.out.println("原数组的顺序:"+Arrays.toString(ia));
得到的结果:

list1打乱前的顺序:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
list1打乱后的顺序:[10, 5, 2, 9, 3, 1, 8, 7, 6, 4]
原数组的顺序:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

将上面的代码改一改:

List<Integer> list2 = Arrays.asList(ia);
System.out.println("list2打乱前的顺序:"+list2.toString());
Collections.shuffle(list2,rand);
System.out.println("list2打乱后的顺序:"+list2.toString());
System.out.println("原数组的顺序:"+Arrays.toString(ia));
得到的结果:

list2打乱前的顺序:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
list2打乱后的顺序:[1, 10, 8, 6, 9, 4, 2, 7, 5, 3]
原数组的顺序:[1, 10, 8, 6, 9, 4, 2, 7, 5, 3]

对比一下,第二段代码将原数组的顺序也打乱了。第一段代码用了一个ArrayList将Arrays.asList()方法的结果包装起来,这将创建一个引用ia数组的元素的ArrayList。因此打乱这些引用不会修改数组。第二段代码直接使用 Arrays.asList()的结果,这种打乱会修改ia数组的顺序。ArrayList.asList()方法的产生的List会使用底层数组作为其物料实现。如果不想改变原数据的位置,那么就使用第一段代码的实现方式。

原文地址:https://www.cnblogs.com/foxting/p/8443977.html