java中对象集合的比较与排序

现种方式。一是对象本身直接实现Comparable接口
class Student implements Comparable{
	private int age;
	
	private String name;
	
	
	//实现Comparable接口方法
	public int compareTo(Object o){
		Student s = (Object)o;
		//当前对象的值大于被比较的对象值返回正数据,等于被比较对象的值返回0,小于被比较对象的值返回负数
		return age>s.age ? 1 : (age=s.age ? 0 :-1);
	}
}

另一种是借助比较器对象,这个比较器对象针对指定的类来定义。并实现Comparator接口
class Student{
	private int age;
	
	private String name;
	
	//可以通过内部类实现一个类型的比较器
	static class StudentComparator implements Comparator<Student>{
		public int compare(Student s1, Student s2){
			return s1.age>s2.age ? 1 : (s1.age=s2.age ? 0 : -1);
		}
	}
}


最后借助Conections.sort(),或ArrayList的sort()方来比较
Colections.sort(studentList, new Student.StudentComparator());

你可能感兴趣的:(java)