使用Jakarta Commons实现一个BeanComparator

本文介绍了一种利用BeanComparator工具实现JavaBean列表排序的方法,该工具基于Jakarta Commons BeanUtils构建,能按不同属性对JavaBean进行灵活排序。

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

反射是可以节省时间和工作的一个强大工具,让它有用的一种方式是通过使用BeanComparator。 
BeanComparator是可以应用于任何JavaBean 的通用比较器(comparator),因为良好的底层bean反射系统,他们可以用bean属性、数组、集合和映射处理一个bean。 
如果我们一个类型为Person 的JavaBean的列表(java.util.List),而Person有一个整型的年龄,字符串型的名字和一个国家,类型为Country的另外一个JavaBean (它又有一个字符串的名字),那么我们就可以用一个BeanComparator 以任何我们想要的方式对它进行排序。 
一些范例: 

  1. List people = ...; // Person对象的列表
  2. BeanComparator comp = new BeanComparator("age");
  3. Collections.sort(list, comp);
  4. BeanComparator comp = new BeanComparator("name");
  5. Collections.sort(list, comp);
  6. BeanComparator comp = new BeanComparator("country.name");
  7. Collections.sort(list, comp); 


没有必要写一个带很多排序属性选项的PersonComparator类,而是写一个单独的BeanComparator类处理全部事情。 
所有的魔术都被底层的反射API处理了。下面是建立在Jakarta Commons BeanUtils 工程上的一个简单的BeanComparator: 

  1. import java.util.Comparator;
  2. import org.apache.commons.beanutils.PropertyUtils;
  3. import org.apache.commons.collections.comparators.ComparableComparator;
  4. public class BeanComparator implements Comparator {
  5.     private String attribute;
  6.     private Comparator comp = new ComparableComparator();
  7.     public BeanComparator(String attrib) {
  8.         this.attribute = attrib;
  9.     }
  10.     public int compare(Object o1, Object o2) {
  11.         if(o1 == null) {
  12.             return 1;
  13.         } else
  14.         if(o2 == null) {
  15.             return -1;
  16.         }
  17.         
  18.         try {
  19.             Object ret1 = PropertyUtils.getProperty(o1, this.attribute);
  20.             Object ret2 = PropertyUtils.getProperty(o2, this.attribute);
  21.             return this.comp.compare(ret1, ret2);
  22.         } catch(Exception e) {
  23.             return 0;
  24.         }
  25.     }


在这个例子中异常处理被简化了并且它假设要进行比较的bean属性通过使用Jakarta Commons Collections工程中的ComparableComparator实现了Comparable接口。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值