Java提供了一个操作Set、List和Map等集合的工具类:Collections,该工具类里 提供了大量方法对集合元素进行排序、查询和修改等操作,还提供了对集合对象实现同步控制等方法。
一、 排序操作
如下示例:
public class CollectionsSort {public static void main(String[] args) {List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(3);list.add(4);list.add(5);list.add(6); System.out.println(list);//reverse 反转 指定列表中元素的顺序。Collections.reverse(list);System.out.println("倒序:"+list);//shuffle 使用默认随机源对指定列表进行置换。Collections.shuffle(list);System.out.println("随机顺序:"+list);//sort 根据元素的自然顺序 对指定列表按升序进行排序。Collections.sort(list);System.out.println("自然顺序排序:"+list);//自定义排序:Collections.sort(list,new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return o2-01; //从大到小}});System.out.println("自定义排序:"+list);//swap 在指定列表的指定位置处交换元素。Collections.swap(list, 1, 5);System.out.println("交换元素:"+list);//rotate 根据指定的距离轮换指定列表中的元素。Collections.sort(list);System.out.println(list);Collections.rotate(list, 2);System.out.println("轮换1:"+list);Collections.rotate(list, -2);System.out.println("轮换2"+list); }
}
执行结果如下:
二、查找和替换操作
public class CollectionsSearch {public static void main(String[] args) {List<Integer> list = new ArrayList<>(); list.add(1);list.add(2);list.add(3);list.add(4);list.add(5);list.add(6);list.add(7);list.add(8);list.add(9);list.add(8);list.add(8);list.add(8); System.out.println(list);//使用二分搜索法搜索指定列表,以获得指定对象。System.out.println("---二分搜索法---");System.out.println(Collections.binarySearch(list, 6));//max minSystem.out.println("---max/min---");System.out.println(Collections.max(list));System.out.println(Collections.min(list)); //frequency 返回元素在列表中出现的次数System.out.println("---frequency---");System.out.println(Collections.frequency(list, 2));System.out.println("---列表---");System.out.println(list);//返回指定源列表中第一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回 -1。System.out.println("—
indexOfSubList/lastIndexOfSubList---");List<Integer> list2 = new ArrayList<>();list2.add(7);list2.add(8);list2.add(9);//返回指定源列表中第一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回 -1。System.out.println(Collections.indexOfSubList(list, list2));//返回指定源列表中最后一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回 -1。System.out.println(Collections.lastIndexOfSubList(list, list2));//replaceAll 使用另一个值替换列表中出现的所有某一指定值。System.out.println("---replaceAll---");Collections.replaceAll(list, 8, 10);System.out.println(list);//fill 使用指定元素替换指定列表中的所有元素。 填充所有System.out.println("---fill---");Collections.fill(list, 2);System.out.println(list);}
}
结果如下:
查找和替换操作参考:
三.同步控制
Collections类中提供了多个 synchronized…()方法,这些方法可以将指定集合包装成线 程同步(线程安全)的集合,从而可以解决多线程并发访问集合时的线程安全问题。 Java中常用的集合框架中的实现类 ArrayList、Linkedlist、 HashSet、TreeSet、 HashMap和TreeMap都是线程不安全的。如果有多个线程访问它们,而且有超过一个 的线程试图修改它们,则存在线程安全的问题。 Collections提供了多个类方法可以把 它们包装成线程同步的集合。
public class SynchronizedDemo {public static void main(String[] args) { List<String>list = Collections.synchronizedList(new ArrayList<String>());Set<String>set = Collections.synchronizedSet(new HashSet<String>());Map<Integer, String>map = Collections.synchronizedMap(new HashMap<Integer, String>()); }
}