java中提供了对集合进行操作的工具类Collections,
Collections对集合中的元素提供了默认的排序方法,sort(),根据元素的自然顺序 对指定列表按升序进行排序。
这里举两个例子来说明下这个方法
1.首先是一个简单的例子
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class Test_02 {
public static void main(String[] args) {
//创建
List<Integer> list = new ArrayList<Integer>();
list.add(3);
list.add(2);
list.add(5);
list.add(7);
System.out.println(list);
//排序
Collections.sort(list);
System.out.println(list);
}
}
输出结果:
[3, 2, 5, 7]
[2, 3, 5, 7]
对于这个例子,Integer类自己实现好了Comparable接口,并且重写了comepareTo方法,所以我们可以直接调用方法就可以实现排序,那么有些人可能会有些疑问,下面的例子可能会解决你的这些问题。
2.对于一些,自己创建的类,比如Person类,想根据里面的年龄属性进行排序的话,那么就需要实现Comparable接口,并且重写compareTo方法,这样就可以根据自己的需要,调用sort方法去排序啦,代码附下
public class Person implements Comparable<Person> {
private String name;
private int 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;
}
public Person() {
}
public Person(String name,int age) {
this.name = name;
this.age = age;
}
@Override
public int compareTo(Person p) {
if(age > p.getAge()) {
return 1;
}else if(age == p.getAge()) {
return 0;
}
return -1;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
}
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class Test_01 {
public static void main(String[] args) {
List<Person> list = new ArrayList<Person>();
list.add(new Person("张三",22));
list.add(new Person("李四",19));
list.add(new Person("王五",23));
list.add(new Person("赵六",18));
System.out.println(list);
Collections.sort(list);
System.out.println(list);
}
}
输出结果:
[Person [name=张三, age=22], Person [name=李四, age=19], Person [name=王五, age=23], Person [name=赵六, age=18]]
[Person [name=赵六, age=18], Person [name=李四, age=19], Person [name=张三, age=22], Person [name=王五, age=23]]