Comparable与Comparator区别

本文详细介绍了Java中Comparable和Comparator接口的使用方法及其实现细节。通过具体的Student类实例展示了如何实现自然排序与定制排序,并提供了完整的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

接口 Comparable<T>  此接口强调对实现它的每个类的对象进行强加一个整体排序, 被称为类的自然排序(类自己拥有排序方法)

实现Comparable<T>接口重写comparaTo(T o)方法(有自然顺序的就没必要重写了)

public class Student implements Comparable<Student> {
	private String name;
	private String age;
	public Student(String name, String age) {
		super();
		this.name = name;
		this.age = age;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getAge() {
		return age;
	}
	public void setAge(String age) {
		this.age = age;
	}
	@Override
	public int compareTo(Student o) {
		// TODO Auto-generated method stub
		int i=	Integer.valueOf(this.age);
		int	j=Integer.valueOf(o.age);
		if(i<j){
			return -1;
		}else if(i>j){
			return 1;
		}else{
		return 0;
		}
	}	

 

接口Comparator<T> 重写compare(T o,T o1) 对一些对象的集合施加了一个整体排序比较器传递给排序方法(如Collections.sort或Arrays.sort )以便对排序顺序进行精确控制。

public class ComparatorDemo implements Comparator<Student>{
	@Override
	public int compare(Student o1, Student o2) {
		// TODO Auto-generated method stub
		if(o1==null||o2==null){
			return 0;
		}
		int i=	Integer.valueOf(o1.getAge());
		int	j=Integer.valueOf(o2.getAge());
		if(i<j){
			return -1;
		}else if(i>j){
			return 1;
		}else{
		return 0;
		}
	}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值