往集合中添加一些元素
Collections.addAll(str, "a", "b", "c");
随机打乱集合
Collections.shuffle(str);
将集合中的元素按照默认规则排序(升序)
Collections.sort(str);
对自定义类型排序(除非 重写compareTo()方法 ),否则不能用。
必须实现Compare接口,重写compareTo方法定义排序。
public class Person implements Comparable<Person>{ @Override public int compareTo(Person o) { //return 0; //认为元素都是相同的 //自定义规则,比较年龄(this.参数Person) return this.getAge() - o.getAge(); //升序 return o.getAge() - this.getAge(); //降序 } }
自己(this) - 参数 :升序 参数 - 自己(this) :降序
将集合中元素按照指定规则排序
Comparable:自己(this)和别人(参数)比较,自己需要实现Comparable接口,重写compareTo方法。
Comparator:相当于找一个第三方的裁判,比较两个
也需要重写比较方法compare();
Collections.sort(str, new Comparator<Integer>() { //重写比较的规则 @Override public int compare(Integer o1, Integer o2) { return o1 - o2; //升序 // return o2 - o1; //降序 } });
Collections.sort(str, new Comparator<Person>() { //重写比较的规则 @Override public int compare(Person o1, Person o2) { int i = o1.getAge() - o2.getAge(); if (i == 0) { //如果年龄一致,比较字符串 return o1.getName().charAt(0) - o2.getName().charAt(0); } else { return o1.getAge() - o2.getAge(); } } });