java集合某个字段按照中文拼音排序

时间:2021-11-04 15:01:43

List 中的ArrayList本身是按照添加顺序排列的,但是有时候想自定义排序方式怎么办呢?

1、List<Record>中的Record 实现 Comparable<Record>接口并复写compareto方法

  1. public class Record implements Comparable<Record> {  
  2.     private String name;  
  3.   
  4.     public String getName() {  
  5.         return name;  
  6.     }  
  7.   
  8.     public void setName(String name) {  
  9.         this.name = name;  
  10.     }  
  11.   
  12.     @Override  
  13.     public int compareTo(Record o) {  
  14.         return name.compareTo(o.name);  
  15.     }  
  16. }  
然后再比较的时候调用实现排序
  1. Collections.sort(list);  


2、第二种方式,通过内部类实现排序
  1. public static void main(String[] args) {  
  2.         List<Record> list = new ArrayList<Record>();  
  3.         Collections.sort(list, new Comparator<Record>() {  
  4.             public int compare(Record o1, Record o2) {  
  5.                 return o1.getName().compareTo(o2.getName())  
  6.             };  
  7.         });  
  8.     }  

附:按照汉字的字典序列进行排序
  1. package com.datayes.ecoinfo;  
  2.   
  3. import java.text.Collator;  
  4. import java.util.ArrayList;  
  5. import java.util.Collections;  
  6. import java.util.Comparator;  
  7. import java.util.List;  
  8.   
  9. public class Test {  
  10.     public static void main(String[] args) {  
  11.         List<String> list = new ArrayList<String>();  
  12.         list.add("你");  
  13.         list.add("好");  
  14.         list.add("啊");  
  15.         Collections.sort(list, new Comparator<String>() {  
  16.             @Override  
  17.             public int compare(String o1, String o2) {  
  18.                 Comparator<Object> com = Collator.getInstance(java.util.Locale.CHINA);  
  19.                 return com.compare(o1, o2);  
  20.   
  21.             }  
  22.         });  
  23.   
  24.         for (String temp : list) {  
  25.             System.out.println(temp);  
  26.         }  
  27.     }  
  28. }  

//自己测试的     好用
List<A> list1 = new ArrayList<A>();
		A a = new A();
		a.setName("滴滴");
		A b = new A();
		b.setName("大哥哥");
		A c = new A();
		c.setName("李莲英");
		A d = new A();
		d.setName("杨坤");
		A e = new A();
		e.setName("李连杰");
		A f = new A();
		f.setName("成员");
		A g = new A();
		g.setName("赵润发");
		A h = new A();
		h.setName("欧阳娜娜");
		list1.add(a);
		list1.add(b);
		list1.add(c);
		list1.add(d);
		list1.add(e);
		list1.add(f);
		list1.add(g);
		list1.add(h);
		Collections.sort(list1, new Comparator<A>() {
			@Override
			public int compare(A o1, A o2) {
				Comparator<Object> com = Collator.getInstance(java.util.Locale.CHINA);
				return com.compare(o1.getName(), o2.getName());

			}
		});
		for (int i = 0; i < list1.size(); i++) {
			System.out.println(list1.get(i).getName());
		}


jdk自带的Collator包涵的汉字太少了,对一些生僻的姓氏不能进行排序。推荐使用:

  1. import com.ibm.icu.text.Collator;  

是ibm开发的针对编码的工具包,非常好用。附pom文件:

  1. <dependency>  
  2.             <groupId>com.ibm.icu</groupId>  
  3.             <artifactId>icu4j</artifactId>  
  4.             <version>57.1</version>  
  5.         </dependency>