qingqing3721 2011-8-30 22:49
Java.util.Collections类包的学习
Java.util.Collections类包的学习 1. 描画: 1.1 概述 java.util.Collections类包括很多有用的办法,可以使顺序员的任务变得愈加容易,但是这些办法通常都没有被充沛地应用。Javadoc给出Collections类最完好的描画列子: import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.Comparator; import java.util.List; public class CollectionsSort { public CollectionsSort() { } public static void main(String[] args) { double array[] = {111, 111, 23, 456, 231 }; List list = new ArrayList(); List li = new ArrayList(); for (int i = 0; i array.length; i++) { list.add(new Double(array[i])); //list.add(""+array[i]); } double arr[] = {111}; for(int j=0;jarr.length;j++){ li.add(new Double(arr[j])); } } 2. 详细操作 1) 排序(Sort) 使用sort办法可以根据元素的自然顺序 对指定列表按升序进行排序。列表中的所有元素都必需完成 Comparable 接口。此列表内的所有元素都必需是使用指定比较器可相互比较的 double array[] = {112, 111, 23, 456, 231 }; for (int i = 0; i array.length; i++) { list.add(new Double(array[i])); } Collections.sort(list); for (int i = 0; i array.length; i++) { System.out.println(li.get(i)); } //后果:112,111,23,[url=http://www.topit.me/user/748096/albums/][color=black]it[/color][/url]456,231 2) 混排(Shuffling) 混排算法所做的正好与 sort 相反: 它打乱在一个 List 中可能有的任何排列的踪迹。也就是说,基于随机源的输入重排该 List, 这样的排列具有相同的可能性(假定随机源是公正的)。这个算法在完成一个碰运气的游戏中是十分有用的。例如,它可被用来混排代表一副牌的 Card 对象的一个 List 。另外,在生成测试案例时,它也是十分有用的。 Collections.Shuffling(list) double array[] = {112, 111, 23, 456, 231 }; for (int i = 0; i array.length; i++) { list.add(new Double(array[i])); } Collections.shuffle(list); for (int i = 0; i array.length; i++) { System.out.println(li.get(i)); } //后果:112,111,23,456,231