1. Collections 工具类介绍
- Collections是一个操作Set、 List和Map等集合的工具类
- Collections中提供了一系列静态的方法对集合元素进行排序、查询和修改等操作
2. 排序操作 (均为 static 方法)
-
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);
- 可以看到顺序是反着的
-
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次,可以看到每次输出的顺序都是不一样的
-
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);
- 就是按照字母的顺序来排序
-
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);
-
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. 查找、替换操作
-
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 排在最后
-
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);
3. 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));
-
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);
-
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"));
-
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);
-
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);