Comparator 比较器可以对两个雷进行比较,但是写起来比较麻烦,不利于使用,可以写一个公共的类,使用 apache commons包来实现。不过这种实现方式有一个问题,中文排序是按照 Unicode 字符码来比较的,不是根据拼音,排序后近似乱序,效果不好。需要指定中文排序方式。
需要引入 apache-common 的 beanutils、collections
· 单个排序
/**
* List 数组排序
* @param <E>
*/
@SuppressWarnings("unchecked")
public static <E> void sort(List<?> list, String key, String desc) {
try {
Comparator<?> comparator = new Comparator<E>() {
@Override
public int compare(E obj1, E obj2) {
// 定义中文语境
Collator instance = Collator.getInstance(Locale.CHINA);
return instance.compare(obj1, obj2);
}
};
comparator = ComparatorUtils.nullLowComparator(comparator);
if ("desc".equals(desc)) {
comparator = ComparatorUtils.reversedComparator(comparator);
}
Collections.sort(list, new BeanComparator(key, comparator));
} catch (Exception e) {
Logger.exception(e);
}
}
· 组合排序
/**
* 组合排序
*/
@SuppressWarnings("unchecked")
public static <E> void sortMulti(List<?> list, String desc, String... keys) {
try {
Comparator<?> comparator = new Comparator<E>() {
@Override
public int compare(E obj1, E obj2) {
// 定义中文语境
Collator instance = Collator.getInstance(Locale.CHINA);
return instance.compare(obj1, obj2);
}
};
comparator = ComparatorUtils.nullLowComparator(comparator);
if ("desc".equals(desc)) {
comparator = ComparatorUtils.reversedComparator(comparator);
}
// 创建一个排序链
ComparatorChain<Object> multiSort = new ComparatorChain<>();
for (String key : keys) {
multiSort.addComparator(new BeanComparator(key, comparator)); // 批量添加排序规则
}
// 开始真正的排序,按照先添加先排序的规则
Collections.sort(list, multiSort);
} catch (Exception e) {
Logger.exception(e);
}
}