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

  • 相关阅读:
    ReentrantLock和AQS
    CAS
    java8中ConcurrentHashMap
    java8中的HashMap
    TCP和UDP
    慢查询日志和profiling
    explain的使用
    select、poll、epoll之间的区别
    I/O模型
    生产者-消费者模式
  • 原文地址:https://www.cnblogs.com/foxting/p/8443977.html
Copyright © 2011-2022 走看看