内容简介:遇到了一个对包含中文的字符串进行排序的问题。要求按unicode编码对字符串进行排序。测试字符串数组如下:按unicode排序的期望结果应该是这样的:
遇到了一个对包含中文的字符串进行 排序 的问题。要求按unicode编码对字符串进行排序。
测试字符串数组如下:
String[] arr = {
"1-测试",
"1-编辑",
"1-营销",
"1结束",
"2-测试",
"1-qt"
};
按unicode排序的期望结果应该是这样的:
1-编辑, 1-测试, 1-营销, 1-qt, 1结束, 2-测试
先按java.lang.String类提供的默认比较方案进行实现,大致如下:
import java.util.Arrays;
import java.util.Comparator;
public class MyJob {
public static void main(String[] args) {
String[] arr = {
"1-测试",
"1-编辑",
"1-营销",
"1结束",
"2-测试",
"1-qt"
};
Comparator<String> c = String::compareTo;
Arrays.sort(arr, c);
System.out.println(Arrays.toString(arr));
}
}
结果如下:
[1-qt, 1-测试, 1-编辑, 1-营销, 1结束, 2-测试]
可以看到中文字符不能按照拼音进行排序。这时最直接的思路就是将中文字符转为拼音后再进行排序。但是要注意下,在这里面有个字符串不包含中文字符,这就容易导致顺序混乱。
如下面这几个字符串按拼音进行排序顺序如下:
1-编辑,1-测试,1-qt,1-营销
可以看到字符串“1-qt”的位置出错了。 但是按拼音来说它的位置又是对的。这不能不说是一个让人有些头疼的地方。
不过不用担心,java提供了java.text.Collator类来支持规范化的字符串比较。
使用Collator来改造之前的代码:
import java.text.Collator;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Locale;
public class MyJob {
public static void main(String[] args) {
String[] arr = {
"1-测试",
"1-编辑",
"1-营销",
"1结束",
"2-测试",
"1-qt"
};
Comparator<String> c = (o1, o2) -> Collator.getInstance(Locale.CHINESE).compare(o1, o2);
Arrays.sort(arr, c);
System.out.println(Arrays.toString(arr));
}
}
改造后的程序执行排序的结果如下:
[1-qt, 1-编辑, 1-测试, 1结束, 1-营销, 2-测试]
结果看着好像还OK。但是停停、注意下、字符串“1结束”的位置好像比较奇妙,理想情况下它应该在“1-营销”的后面。
这里出问题的原因我没有弄清楚。猜测着应该是 java 在Chinese语法中将中划线处理为空字符了。不过最根本的问题还是java对Unicode Collation Algorithm(UCA,Unicode整理算法)的支持并不好。
此时可以考虑使用IBM ICU提供的Collator来替换jdk默认的Collator。代码如下:
import com.ibm.icu.text.Collator;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Locale;
public class MyJob {
public static void main(String[] args) {
String[] arr = {
"1-测试",
"1-编辑",
"1-营销",
"1结束",
"2-测试",
"1-qt"
};
Comparator<String> c = (o1, o2) -> Collator.getInstance(Locale.CHINESE).compare(o1, o2);
Arrays.sort(arr, c);
System.out.println(Arrays.toString(arr));
}
}
相关的依赖为:
<dependency> <groupId>com.ibm.icu</groupId> <artifactId>icu4j-localespi</artifactId> <version>60.2</version> </dependency>
执行结果为:
[1-编辑, 1-测试, 1-营销, 1-qt, 1结束, 2-测试]
可以看到是和预期一致的。
参考文档
##########
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C++程序设计原理与实践
(美)Bjarne Stroustrup / 王刚 等 / 机械工业出版社 / 2010.7 / 108.00元
本书是经典程序设计思想与C++开发实践的完美结合,是C++之父回归校园后对C++编程原理和技巧的全新阐述。书中全面地介绍了程序设计基本原理,包括基本概念、设计和编程技术、语言特性以及标准库等,教你学会如何编写具有输入、输出、计算以及简单图形显示等功能的程序。此外,本书通过对C++思想和历史的讨论、对经典实例(如矩阵运算、文本处理、测试以及嵌入式系统程序设计)的展示,以及对C语言的简单描述,为你呈现......一起来看看 《C++程序设计原理与实践》 这本书的介绍吧!