java对汉字排序(按照拼⾳字母排序)业务场景:
⼀个list集合,⾥⾯add了若⼲个实体类,针对该实体类排序的属性为String。
使⽤技术,⾃定义list排序(JDK⾃带),重写Comparator接⼝的compare⽅法,汉字转拼⾳技术:使⽤的pinyin4j。
pinyin4j官⽹地址:pinyin4j.sourceforge/
不想去官⽹下载的我这⾥也有,地址为:
//tempRateList 为需要进⾏⾃定义排序的集合,SpRate为该集合的实体类,riskName为排序的属性。
直接上⽅案:
1、导⼊pinyin4j-2.5.0.jar;
2、对⾃定义排序的类使⽤以下⽅法进⾏⾃定义排序;
[java]
1. Collections.sort(tempRateList,new Comparator<SpRate>() {
2.    @Overridejava集合排序怎么实现
3.    public int compare(SpRate s1, SpRate s2) {
4.        String o1 = s1.getRiskName();
5.        String o2 = s2.getRiskName();
6.        for (int i = 0; i < o1.length() && i < o2.length(); i++) {
7.
8.        int codePoint1 = o1.charAt(i);
9.        int codePoint2 = o2.charAt(i);
10.
11.        if (Character.isSupplementaryCodePoint(codePoint1)
12.            || Character.isSupplementaryCodePoint(codePoint2)) {
13.        i++;
14.        }
15.
16.        if (codePoint1 != codePoint2) {
17.        if (Character.isSupplementaryCodePoint(codePoint1)
18.            || Character.isSupplementaryCodePoint(codePoint2)) {
19.            return codePoint1 - codePoint2;
20.        }
21.
22.        String pinyin1 = HanyuPinyinStringArray((char) codePoint1) == null
23.                ? null : HanyuPinyinStringArray((char) codePoint1)[0];
24.        String pinyin2 = HanyuPinyinStringArray((char) codePoint2) == null
25.                ? null : HanyuPinyinStringArray((char) codePoint2)[0];
26.
27.        if (pinyin1 != null && pinyin2 != null) { // 两个字符都是汉字
28.            if (!pinyin1.equals(pinyin2)) {
29.            return pinyin1pareTo(pinyin2);
30.            }
31.        } else {
32.            return codePoint1 - codePoint2;
33.        }
34.        }
35.    }
36.    return o1.length() - o2.length();
37.    }
38. });
3、⽅法结束后  tempRateList 对象就完成了⾃定义排序