今天上水木发现有人问怎样对汉字字符串按照拼音排序,查了一遍文档,发现java缺省对字符串是按照每个Unicode字符的编码大小排序的。接着查到(要是没有了Google,世界将会怎样?)有一个java.text.Collator类,但是论坛上有人说这个类没用,和缺省的排序效果一样,要用C#写一个类生成java程序。这要是真的,那还学java干嘛?
于是把别人的Test.java改了改,分别用指定的Locale和不指定Locale试了试,结果都是OK的:
import java.util.*;
import java.text.*;
public class Test2 {
public static void testDefault() {
String[] arr = {"张三", "李四", "王五", "刘六"};
Arrays.sort(arr);
for (int i = 0; i < arr.length; i++)
System.out.println(arr[i]);
System.out.println();
}
public static void testChinaLocale() {
//Comparator cmp = (RuleBasedCollator)java.text.Collator.getInstance(java.util.Locale.CHINA);//try testing various locales
Comparator cmp = Collator.getInstance(java.util.Locale.CHINA);
String[] arr = {"张三", "李四", "王五", "刘六"};
Arrays.sort(arr, cmp);
for (int i = 0; i < arr.length; i++)
System.out.println(arr[i]);
System.out.println();
}
public static void testDefaultLocale() {
//Comparator cmp = (RuleBasedCollator)java.text.Collator.getInstance(java.util.Locale.CHINA);//try testing various locales
Comparator cmp = Collator.getInstance();
String[] arr = {"张三", "李四", "王五", "刘六"};
Arrays.sort(arr, cmp);
for (int i = 0; i < arr.length; i++)
System.out.println(arr[i]);
System.out.println();
}
public static void main(String args[]) {
testDefault();
testChinaLocale();
testDefaultLocale();
}
}
输出结果:
刘六
张三
李四
王五
李四
刘六
王五
张三
李四
刘六
王五
张三
原文出自:http://hi.baidu.com/luyanlong1/item/4d80b531994b2194c2cf2911