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