java对象属性排序,Java对象属性比较排序

前言:

关于Java中的排序,我们常见的就是对Array、List进行排序,对于Array,我们可以使用Arrays.sort(数组)进行排序;对于List,我们可以使用Collections.sort(list)进行排序,如果是需要对一个实体类的对象进行排序呢?

Comparator接口有一个comparTo(Object o)方法,它返回整数类型。对于表达式x.compareTo(y),如果返回值为0,则表示x和y相等,如果返回值大于0,则表示x大于y,如果返回值小于0,则表示x小于y;这是一个比较器接口。

因此,我们可以通过实现Comparator接口的compareTo方法对对象进行排序;

根据汉字首字母排序并进行分组 请移步这里 https://blog..net/Muscleheng/article/details/82666166

需求:有一个人员类,需要对其进行排,排序规则有:根据id排序、根据姓名排序、根据年龄排序;

第一步:创建一个人员类

package com.sort;

public class Person {

// id

private String id;

// 姓名

private String name;

// 年龄

private String age;

/**

* 初始构造方法

* @param id 编号

* @param name 姓名

* @param age 年龄

*/

public Person(String id,String name,String age) {

this.id = id;

this.name = name;

this.age = age;

}

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

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 String toString() {

return "Person [id=" + id + ", name=" + name + ", age=" + age + "]";

}

}

第二步:写一个排序的方法并调用

package com.sort;

import java.util.Collections;

import java.util.Comparator;

import java.util.LinkedList;

import java.util.List;

public class Test {

public static void main(String[] args) {

Person person1 = new Person("1001","cccc", "22");

Person person2 = new Person("1002","aaaa", "23");

Person person3 = new Person("1003","bbbb", "21");

// 把对象添加到list集合里面

List list = new LinkedList();

list.add(person3);

list.add(person1);

list.add(person2);

System.out.println("排序前:");

for (Person person : list) {

System.out.println(person.toString());

}

System.out.println("\n排序后(按id排序):");

for (Person person : Test.personSort(list, "id")) {

System.out.println(person.toString());

}

}

/**

* 对Person对象进行排序

* @param list 排序对象的集合

* @param param 排序规则参数(id:根据 id 排序,name:根据 姓名 排序,age:根据 年龄 排序)

* @return 返回排序完成后的对象

*/

public static List personSort(List list,final String param) {

Collections.sort(list, new Comparator() {

@Override

public int compare(Person p1, Person p2) {

// 根据 id 排序

if ("id".equals(param)) {

//System.out.println(p1.getId().compareTo(p2.getId()));

return p1.getId().compareTo(p2.getId());

}

// 根据 name 排序

if ("name".equals(param)) {

return p1.getName().compareTo(p2.getName());

}

// 根据 age 排序

if ("age".equals(param)) {

return p1.getAge().compareTo(p2.getAge());

}

// 否则不进行排序

return 0;

}

});

return list;

}

}

其中,我们通过传入不同的参数实现不同的排序规则;

排序结果展示:

Person person1 = new Person("1001","cccc", "22");

Person person2 = new Person("1002","aaaa", "23");

Person person3 = new Person("1003","bbbb", "21");

一、按照id排序结果:

85e65655d4a67bade6e548177cf4c67c.png

二、按照name排序结果:

0a11d045340469e7b121f5a3a4a12121.png

三、按照age排序结果:

b123353c7fae451775895eadfd90c894.png

从排序结果可以看出,我们已经实现了我们想要的排序结果;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值