java.utils.Collections 是集合工具类,用来对集合进行操作,具体方法有:
public static boolean addAll(Collection c, T…elements):往集合中添加一些元素
public static void shuffle(List<?> list):打乱集合的顺序
public static void sort(List list):将集合中元素按照默认规则排序
public static void sort(List list, Comparator<? super T>):将集合中元素按照指定规则排序
public static void sort(List list, Comparator<? super T>):将集合中元素按照指定规则排序
package lesson;
public class Person implements Comparable<Person>{
private String name;
private int age;
public Person() {
}
public Person(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
//重写排序的规则
@Override
public int compareTo(Person o) {
//return 0; //认为元素都是相同的
//自定义比较的规则,比较两个人的年龄(this,参数Person)
return this.getAge()-o.getAge();//按照年龄升序排序
}
}
package lesson;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
/*
java.utils.Collections 是集合工具类,用来对集合进行操作,具体方法有:
public static <T> boolean addAll(Collection<T> c, T...elements):往集合中添加一些元素
public static void shuffle(List<?> list):打乱集合的顺序
public static <T> void sort(List<T> list):将集合中元素按照默认规则排序
public static <T> void sort(List<T> list, Comparator<? super T>):将集合中元素按照指定规则排序
注意:
sort(List<T> list)使用前提:
被排序的集合里边存储的元素,必须实现接口Comparable,重写接口中的方法compareTo 定义排序的规则
如果排序的是自定义类型,需要重写compareTo方法
Comparable接口排序规则:
自己(this)-参数:升序
*/
public class Demo01Collections {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();
//往集合中添加多个元素
// public static <T> boolean addAll(Collection<T> c, T...elements):往集合中添加一些元素
Collections.addAll(list,"a","b","c","d");
System.out.println(list);//[a, b, c, d]
//public static void shuffle(List<?> list):打乱集合的顺序
Collections.shuffle(list);
System.out.println(list);//[c, d, a, b] 每次执行顺序都不一样
System.out.println("====================");
ArrayList<Integer> list01 = new ArrayList<>();
list01.add(2);
list01.add(4);
list01.add(3);
list01.add(1);
System.out.println(list01);//[2, 4, 3, 1]
//public static <T> void sort(List<T> list):将集合中元素按照默认规则排序
Collections.sort(list01);//默认升序
System.out.println(list01);//[1, 2, 3, 4]
ArrayList<String> list02 = new ArrayList<>();
list02.add("b");
list02.add("d");
list02.add("c");
list02.add("a");
System.out.println(list02);//[b, d, c, a]
Collections.sort(list02);
System.out.println(list02);//[a, b, c, d]
ArrayList<Person> list03 = new ArrayList<Person>();
list03.add(new Person("张三",18));
list03.add(new Person("李四",20));
list03.add(new Person("王五",15));
System.out.println(list03);
//[Person{name='张三', age=18}, Person{name='李四', age=20}, Person{name='王五', age=15}]
Collections.sort(list03);
System.out.println(list03);
//[Person{name='王五', age=15}, Person{name='张三', age=18}, Person{name='李四', age=20}]
}
}
package lesson;
public class Student {
private String name;
private int age;
public Student() {
}
public Student(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
package lesson;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
/*
public static <T> void sort(List<T> list, Comparator<? super T>):将集合中元素按照指定规则排序
Comparator 和 Comparable 的区别:
Comparable:自己(this)和别人(参数)比较,自己需要实现Comparable接口,重写比较的规则compareTo方法
Comparator:相当于找一个第三方的裁判,比较
Comparator 排序规则:
o1-o2:升序 o2-o1:降序
*/
public class Demo03Sort {
public static void main(String[] args){
ArrayList<Integer> list01 = new ArrayList<>();
list01.add(2);
list01.add(4);
list01.add(3);
list01.add(1);
System.out.println(list01); //[2, 4, 3, 1]
Collections.sort(list01, new Comparator<Integer>() {
//重写比较的规则
@Override
public int compare(Integer o1, Integer o2) {
return o1-o2;//升序
//return o2-o1; 降序
}
});
System.out.println(list01);//[1, 2, 3, 4]
ArrayList<Student> list02 = new ArrayList<>();
list02.add(new Student("孙悟空",999));
list02.add(new Student("猪八戒",666));
list02.add(new Student("沙悟净",777));
// list02.add(new Student("沙悟净",700));
System.out.println(list02);
//[Student{name='孙悟空', age=999}, Student{name='猪八戒', age=666}, Student{name='沙悟净', age=777}]
Collections.sort(list02, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
//按照年龄升序排序
return o1.getAge()- o2.getAge();
}
});
/*Collections.sort(list02, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
//按照年龄升序排序
int result = o1.getAge()- o2.getAge();
//如果年龄相同,再使用姓名
}
});*/
System.out.println(list02);
//[Student{name='猪八戒', age=666}, Student{name='沙悟净', age=777}, Student{name='孙悟空', age=999}]
}
}