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);