重写Collections中的int compare(T o1, T o2)对list进行排序替代冒泡排序

该文章展示了一个Java示例,如何使用Collections.sort方法结合自定义比较器对User对象列表进行排序,排序依据是User对象的id属性。首先创建了User对象列表,然后通过重写Comparator接口的compare方法,根据id属性的数值进行升序排序。

根据集合对象中某一个属性,对整个集合元素进行排序

//重写Collections中的int compare(T o1, T o2)对list进行排序
public class Test01 {
    public static void main(String[] args) {
        User u1 = new User();
        User u2 = new User();
        User u3 = new User();
        User u4 = new User();
        u1.setId("23");
        u2.setId("13");
        u3.setId("3");
        u4.setId("22");
        // 新建一个List
        List<User> list = new ArrayList<>();
        list.add(u1);
        list.add(u2);
        list.add(u3);
        list.add(u4);
        System.out.println("排序前"+list);
        toSort(list);
        System.out.println("升序后"+list);
    }

    private static void toSort(List<User> list) {
        Collections.sort(list, new Comparator<User>() {
            @Override
            public int compare(User o1, User o2) {
                int i1 = Integer.parseInt(o1.getId());
                int i2 = Integer.parseInt(o2.getId());
                return (i1 - i2) < 0 ? -1 : 0;
            }
        });
    }

}

class User {
    private String id;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    @Override
    public String toString() {
        return "User{" +
                "id='" + id + '\'' +
                '}';
    }
}
排序前[User{id='23'}, User{id='13'}, User{id='3'}, User{id='22'}]
升序后[User{id='3'}, User{id='13'}, User{id='22'}, User{id='23'}]

注意:想要打印list集合时,记得在实体类中重写toString()方法,不然的话打印出来的结果是地址

排序前[com.sangeng.collection.User@30f39991, com.sangeng.collection.User@452b3a41, com.sangeng.collection.User@4a574795, com.sangeng.collection.User@f6f4d33]
升序后[com.sangeng.collection.User@4a574795, com.sangeng.collection.User@452b3a41, com.sangeng.collection.User@f6f4d33, com.sangeng.collection.User@30f39991]

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值