1. Collections 工具类介绍1) Collections是一个操作Set、 List和Map等集合的工具类2) Collections中提供了一系列静态的方法对集合元素进行排序、查询和修改等操作2. 排序操作 (均为 static 方法)1) reverse(List): 反转 List 中元素的顺序 List list = new ArrayList(); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); System.out.println("list=" + list); Collections.reverse(list); System.out.println("list=" + list);可以看到顺序是反着的2) shuffle(List): 对 List 集合元素进行随机排序 List list = new ArrayList(); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); System.out.println("list=" + list); Collections.reverse(list); System.out.println("list=" + list); for (int i = 0; i < 3; i++) { Collections.shuffle(list); System.out.println("list=" + list); }遍历3次,可以看到每次输出的顺序都是不一样的3) sort(List): 根据元素的自然顺序对指定 List 集合元素按升序排序 List list = new ArrayList(); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); Collections.sort(list); System.out.println("自然排序后:" + list);就是按照字母的顺序来排序4) sort(List, Comparator): 根据指定的 Comparator 产生的顺序对 List 集合元素进行排序 List list = new ArrayList(); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); //按照 字符串 长度大小来排序 Collections.sort(list, new Comparator() { public int compare(Object o1, Object o2) { if (o1 instanceof String && o2 instanceof String) return ((String)o2).length() - ((String)o1).length(); else return 0; } }); System.out.println("按照字符串长度大小排序后=" + list);5) swap(List, int, int): 将指定 List 集合中的i处元素和j处元素进行交换 List list = new ArrayList(); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); System.out.println("list=" + list); Collections.swap(list, 0, 1); System.out.println("交换后的顺序=" + list);可以看到 坐标 0 和 1 的元素交换了如果坐标越界了,就会报 Index0utOfBoundsException 异常3. 查找、替换操作1) Object max(Collection): 根据元素的自然顺序,返回给定集合中排序最大的元素 List list = new ArrayList(); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); System.out.println("自然排序中的最大元素=" + Collections.max(list));因为按照字幕顺序,x 排在最后2) Object max(Collection, Comparator): 根据Comparator指定的顺序,返回给定集合中的最大元素 List list = new ArrayList(); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); System.out.println("自然排序中的最大元素=" + Collections.max(list)); Object maxObject = Collections.max(list, new Comparator() { public int compare(Object o1, Object o2) { return ((String)o1).length() - ((String)o2).length(); } }); System.out.println("长度最大的元素=" + maxObject);Object min(Collection):根据元素的自然顺序,返回给定集合中排序最小的元素 List list = new ArrayList(); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); System.out.println("自然排序中的最小元素=" + Collections.min(list));4) Object min(Collection, Comparator):根据Comparator指定的顺序,返回给定集合中的最小元素 Object minObject = Collections.max(list, new Comparator() { public int compare(Object o1, Object o2) { return ((String) o2).length() - ((String) o1).length(); } }); System.out.println("长度最小的元素=" + minObject);5) int frequency(Collection, Object): 返回指定集合中指定元素的出现次数 List list = new ArrayList(); list.add("xdr"); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); System.out.println("xdr出现的次数=" + Collections.frequency(list, "xdr"));6) void copy(List dest,List src):将src中的内容复制到dest中 List list = new ArrayList(); list.add("xdr"); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); ArrayList dest = new ArrayList(); // 完成一个完整的拷贝,需要先给 dest 赋值,大小和 list.size() 一样 for (int i = 0; i < list.size(); i++) { dest.add(""); } // 拷贝 Collections.copy(dest, list); System.out.println(dest);7) boolean replaceAll(List list, Object oldVal, Object newVal):使用新值替换 List 对象的所有旧值 List list = new ArrayList(); list.add("xdr"); list.add("xdr"); list.add("tom"); list.add("jack"); list.add("mike"); Collections.replaceAll(list, "xdr", "兮动人"); System.out.println("list替换后=" + list);
