往集合中添加一些元素
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();
}
}
});