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 对象就完成了⾃定义排序
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论