Collections.sort实现list排序

本文介绍了一种使用Java对对象列表进行排序的方法,通过自定义比较器实现按对象内的特定属性(如链接数)进行升序或降序排列,并提供了一个具体的排序示例。

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

对象内某个值排序
首先创建一个对象

public class SortObject {
	
	private String name;
	private int links;
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getLinks() {
		return links;
	}
	public void setLinks(int links) {
		this.links = links;
	}
	public SortObject(String name, int links) {
		super();
		this.name = name;
		this.links = links;
	}

}

然后创建我们测试类

public class ListSort {
	
	public static void main(String[] args) {
		List<SortObject> list = new ArrayList<SortObject>();
		list.add(new SortObject("李1", 1));
		list.add(new SortObject("李3", 3));
		list.add(new SortObject("李4", 4));
		list.add(new SortObject("李2", 2));
		list.add(new SortObject("李6", 6));
		list.add(new SortObject("李5", 5));
		
		Collections.sort(list, new Comparator<SortObject>() {

			@Override
			public int compare(SortObject o1, SortObject o2) {
				
				//return o1.getLinks() - o2.getLinks();
				return o2.getLinks() - o1.getLinks();
			}
		});
		for(int i=0;i<list.size();i++) {
			System.out.println(list.get(i).getName());
			System.out.println(list.get(i).getLinks());
		}
		
	}

}

输出结果:

李6
6
李5
5
李4
4
李3
3
李2
2
李1
1

一个正序一个倒叙

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值