Java中Arrays.sort()自定义数组的排序

Arrays.sort()方法参数为自定义对象数组时的使用

简述

首先Comparable< T t >是一个接口其中有一个抽象方法compareTo,当sort方法参数传入自定义对象数组时,我们跟随源码可以看到最终是以Comparable< T t >这个接口关联到参数数组中对象所在的类中的compareTo方法进行排序的,因此参数对象所对应的类必须实现Comparable< T t >接口,并且重写compareTo方法规定排序策略。

举例说明

1. 首先创建一个类

我们创建一个Lei类(类名自定义)其中有一个String类型的成员变量bookname和int类型的成员变量count,这个类实现了Comparable< T t >接口,并且重写了compareTo(compareTo方法的返回值是大于0,等于0或小于0三种),排序策略是根据int类型的成员变量count的大小进行排序的

this.getCount()-o.getCount()可以大于0,等于0或小于0

public class Lei implements Comparable<Lei> {
	private String bookname;
	private int count;
	public Lei(String bookname, int count) {
		super();
		this.bookname = bookname;
		this.count = count;
	}
	public String getBookname() {
		return bookname;
	}
	public void setBookname(String bookname) {
		this.bookname = bookname;
	}
	public int getCount() {
		return count;
	}
	public void setCount(int count) {
		this.count = count;
	}
	@Override
	public String toString() {
		return "Lei [书名=" + bookname + ", 数量=" + count + "]\n";
	}
	@Override
	public int compareTo(Lei o) {
		// TODO Auto-generated method stub
		return this.getCount()-o.getCount();
	}
	
}
2. 创建一个测试类

其中创建了一个Lei类的对象数组,通过构造方法给成员变量赋值,初始的时候是乱序的,我们把数组名传入sort方法中,然后输出对象数组的内容

public class Test {
	public static void main(String[] args) {
		Lei[] arr=new Lei[5];
	
		arr[0]=new Lei("AA",3);
		arr[1]=new Lei("CC",5);
		arr[2]=new Lei("FF",1);
		arr[3]=new Lei("BB",4);
		arr[4]=new Lei("SS",2);
		Arrays.sort(arr);
		System.out.println(Arrays.toString(arr));
	
	}
}

3.运行结果

我们可以看到数组中的对象已经根据数量(count)的大小排序好了
在这里插入图片描述

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值