原文出自 http://www.blogjava.net/jeff-lau/archive/2007/12/21/169257.html 感谢这位作者。
以下是我仿照原文做的一个比较拼音的中文排序。
下面这段代码测试通过了的,方便大家去调试去理解。。。。我只是菜鸟学学,并没有深入的去理解。。。
但我希望,大家积极的提出问题。。。,我更希望,与大家共同进步。
当然它用到了一个lib我已经提供在附件里面。供大家下载。
public class Person implements Comparable<Person> {
// Comparator<Person>
public Person(){
}
public Person(String name,int age,String phone){
this.name= name;
this.age=age;
this.phone= phone;
}
private String name;
private int age;
private String phone;
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public String toString(){
return getName();
}
public int compare(Person o1, Person o2) {
Comparator cmp = Collator.getInstance(java.util.Locale.JAPAN);
return cmp.compare(o1.getName(), o2.getName());
}
/**
* 字符的拼音,多音字就得到第一个拼音。不是汉字,就return null。
*/
private String pinyin(char c) {
String[] pinyins = PinyinHelper.toHanyuPinyinStringArray(c);
if (pinyins == null) {
return null;
}
return pinyins[0];
}
// public int compare(Person cb1, Person cb2) {
// String o1=cb1.getName();
// String o2 = cb2.getName();
//
// for (int i = 0; i < o1.length() && i < o2.length(); i++) {
//
// int codePoint1 = o1.charAt(i);
// int codePoint2 = o2.charAt(i);
//
// if (Character.isSupplementaryCodePoint(codePoint1)
// || Character.isSupplementaryCodePoint(codePoint2)) {
// i++;
// }
//
// if (codePoint1 != codePoint2) {
// if (Character.isSupplementaryCodePoint(codePoint1)
// || Character.isSupplementaryCodePoint(codePoint2)) {
// return codePoint1 - codePoint2;
// }
//
// String pinyin1 = pinyin((char) codePoint1);
// String pinyin2 = pinyin((char) codePoint2);
//
// if (pinyin1 != null && pinyin2 != null) { // 两个字符都是汉字
// if (!pinyin1.equals(pinyin2)) {
// return pinyin1.compareTo(pinyin2);
// }
// } else {
// return codePoint1 - codePoint2;
// }
// }
// }
// return o1.length() - o2.length();
// }
public static void main(String[] args) {
List<Person> list = new ArrayList<Person>();
Person p1 = new Person("张山",12,"123465789");
Person p2 = new Person("阿狗",12,"123465789");
Person p3 = new Person("李四",12,"123465789");
Person p4 = new Person("张山",12,"123465789");
Person p5 = new Person("李某某",12,"123465789");
Person p6 = new Person("阿某某",12,"123465789");
Person p7 = new Person("瞿某某",12,"123465789");
Person p8 = new Person("张某某",12,"123465789");
Person p9 = new Person("张价",12,"123456789");
list.add(p1);
list.add(p2);
list.add(p3);
list.add(p4);
list.add(p5);
list.add(p6);
list.add(p7);
list.add(p8);
list.add(p9);
// Comparator c = new Person();
Collections.sort(list);
for(int i=0;i<list.size();i++){
System.out.println(list.get(i).getName());
}
}
// public int compareTo(Person o) {
// Comparator cmp = Collator.getInstance(java.util.Locale.CHINESE);
// return cmp.compare(this.getName(), o.getName());
// }
public int compareTo(Person o) {
String o1=this.getName();
String o2 = o.getName();
for (int i = 0; i < o1.length() && i < o2.length(); i++) {
int codePoint1 = o1.charAt(i);
int codePoint2 = o2.charAt(i);
if (Character.isSupplementaryCodePoint(codePoint1)
|| Character.isSupplementaryCodePoint(codePoint2)) {
i++;
}
if (codePoint1 != codePoint2) {
if (Character.isSupplementaryCodePoint(codePoint1)
|| Character.isSupplementaryCodePoint(codePoint2)) {
return codePoint1 - codePoint2;
}
String pinyin1 = pinyin((char) codePoint1);
String pinyin2 = pinyin((char) codePoint2);
if (pinyin1 != null && pinyin2 != null) { // 两个字符都是汉字
if (!pinyin1.equals(pinyin2)) {
return pinyin1.compareTo(pinyin2);
}
} else {
return codePoint1 - codePoint2;
}
}
}
return o1.length() - o2.length();
}
}
分享到:
相关推荐
默认情况下,Java使用自然排序,即按照字符串的Unicode值进行排序,这对于英文字符和数字来说通常是合适的,但对于中文字符则不是我们期望的排序方式。 为了实现中文、数字和字母的排序,我们需要创建一个`...
Java汉字笔画排序是一个在中文处理领域常见的需求,特别是在数据整理、信息检索或者用户界面排序等方面。本项目提供的"java汉字笔画排序2源代码jar包"是一个优化过的解决方案,旨在减少内存占用并提高排序效率。 ...
4. * 汉字按照拼音排序的比较器 5. * @author KennyLee 2009-2-23 10:08:59 6. * 7. */ 8.public class PinyinComparator implements Comparator<Object> { 9. public int compare(Object o1, Object o2) { 10...
标签进一步明确了关键概念,包括"汉字笔画排序"、"java汉字笔画排序"、"java汉字按照笔画排序"、"汉字按照笔画排序"和"中文笔画排序"。这些标签强调了该话题的特定技术点,即使用Java语言对中文字符进行笔画计数并...
在Java编程语言中,处理中文和英文混合的排序问题是一个常见的需求,特别是在处理用户输入、数据库数据或文件名等场景。这个"关于中文英文混合排序javaDemo"的示例主要展示了如何实现这样的功能。让我们深入探讨一下...
本文将详细介绍如何在 Java 中对包含中文姓氏的对象列表或字符串列表进行排序。 #### 二、基本概念 1. **Collator 类**:这是 Java 中用于文本排序和检索的标准类。`Collator` 类提供了与语言环境相关的字符串排序...
在中文环境中,有时我们需要按照汉字的笔画数量来对汉字进行排序,这在信息检索、数据分析、中文文本处理等领域有广泛应用。 标题"java汉字笔画排序源码"表明这是一个关于使用Java编程语言实现汉字笔画排序的代码...
在Java编程语言中,对中文字符串进行排序是一个相对复杂的问题,因为中文字符的排序不能简单地按照Unicode编码顺序来处理。通常,我们需要考虑汉字的拼音或者笔画等属性来进行排序。这里我们将详细介绍如何使用`...
在Java中对于字符串数组的排序,我们可以使用Arrays.sort(String[])方法很便捷的进行排序。例如: String[] arrays = new String[] { gyu, sdf, zf, 大同, 收到, 地方, 三等分, 的人, 反对高铁, 泛代数, 上的投入...
利用java对基本汉字(unicode编码4E00-9FA5)进行笔画排序 资源更新查看:https://blog.csdn.net/u013271384/article/details/76549368
### 知识点一:字符串排序算法在 Java 中的应用 #### 冒泡排序算法实现 冒泡排序是一种简单的排序算法,通过重复遍历要排序的列表,比较每对相邻的元素,并交换它们的位置(如果顺序错误的话),直到没有任何一对...
Java集合某个字段按照中文拼音排序是Java开发中经常遇到的问题。对Java集合中的某个字段按照中文拼音排序可以使用多种方法,本文将介绍两种常见的方法。 方法一:使用Comparable接口 在Java中,我们可以使用...
在Java编程环境中,我们也可以模拟实现这种排序规则。Java提供了丰富的类库和方法来处理文件操作,包括对文件的排序。以下是关于如何在Java中实现Windows文件排序规则的详细解释: 1. **文件对象的创建**: 在Java...
在编程领域,排序算法是计算机科学中的基础概念,它们用于整理数据序列,使其按照特定顺序排列。本主题将深入探讨Java实现的选择排序算法,这是一种简单直观的排序算法,适合新手学习。 选择排序(Selection Sort)...
在Java编程语言中,对字符串中的字符进行a到z排序是一项常见的操作,特别是在处理文本数据或需要对字母顺序排列的场景。本知识点将详细讲解如何实现这个功能。 首先,我们需要理解字符串在Java中的本质。在Java中,...
b) 对于包含中文字符的排序,情况变得复杂,因为中文的排序规则与英文不同。这时,我们需要利用`java.text.Collator`类。`Collator`提供了一种语言敏感的比较字符串的方法。首先,我们需要创建一个`Collator`实例,...
总之,Java中的SortedSet提供了有序存储和操作集合的能力,特别是结合自定义的Comparator,可以实现复杂的排序需求,如中文字符串的自然顺序排序。通过对SortedSet接口和其实现类TreeSet的源码学习,开发者可以更...
在Java和SQL中,汉字排序是一项常见的需求,尤其是在处理中文数据时。在SQL Server中,汉字排序涉及到排序规则,这是决定字符串如何存储、比较和排序的关键因素。排序规则定义了字符的位模式,并且规定了在比较字符...