• 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会使用底层数组作为其物料实现。如果不想改变原数据的位置,那么就使用第一段代码的实现方式。

  • 相关阅读:
    GHOST CMS
    某小姑娘治疗案
    关于ssl证书的一些知识
    Hbuiler中常用的快捷键
    跌落损任胸胁案
    老年脑梗案
    Centos7安装完成后设定基本的网络配置
    Centos7下的文件压缩
    在centos7上用docker安装宝塔面板
    右手中指一侧麻木案
  • 原文地址:https://www.cnblogs.com/foxting/p/8443977.html
Copyright © 2020-2023  润新知