[原创]Java中的字符串比较,按照使用习惯进行比较
java中的字符串比较一般可以采用compareTo函数,如果a.compareTo(b)返回的是小于0的数,那么说明a的unicode编码值小于b的unicode编码值。
但是很多情况下,我们开发一款app需要结合“国情”,比如在电话本中,我们希望“李四”排在“zhangsan”的前面,但是如果采用普通的compareTo函数的字符串比较的方式,那么“zhangsan”小于“李四”,由此造成了“zhangsan”的排序先于“李四”。
解决方式是采用java提供的 Collator类。
一、原理分析:
1 public abstract class Collator implements Comparator<Object>, Cloneable{}
Collator是一个抽象类,实现了Comparator和Clonable接口,Collator的构造方式有以下几种:
1.
1 /** 2 * Returns a {@code Collator} instance which is appropriate for the user's default 3 * {@code Locale}. 4 * See "<a href="../util/Locale.html#default_locale">Be wary of the default locale</a>". 5 */ 6 public static Collator getInstance() { 7 return getInstance(Locale.getDefault()); 8 }
注释中已经注明:返回一个按照用户当地排序规则的Locale作为参数,一般来说getDefault()获取的Locale就会根据中国人的使用习惯进行比较。传入getInstance(Locale)函数中,接着看此函数的实现:
2.
1 /** 2 * Returns a {@code Collator} instance which is appropriate for {@code locale}. 3 */ 4 public static Collator getInstance(Locale locale) { 5 if (locale == null) { 6 throw new NullPointerException("locale == null"); 7 } 8 return new RuleBasedCollator(new RuleBasedCollatorICU(locale)); 9 }
函数生成一个RuleBasedCollator对象,此对象继承了Collator抽象类
二、使用方法
1.工具类实现。
使用方法见下面我写的工具类:
1 public class CompareHelper { 2 3 public static final Collator COLLATOR = Collator.getInstance(); 4 5 public static final Comparator<Contact> COMPARATOR_CONTACT; 6 7 static 8 { 9 COMPARATOR_CONTACT = new Comparator<Contact>(){ 10 public final int compare(Contact a, Contact b){ 11 return COLLATOR.compare(a.sortKeyString, b.sortKeyString); 12 } 13 }; 14 } 15 private CompareHelper(){} 16 }
2.对List元素进行重新排序:
1 Collections.sort(contacts, CompareHelper.COMPARATOR_CONTACT);
3.针对两个字符串进行“本地化”比较,使用的方法是:
int compareRet = CompareHelper.COLLATOR.compare(stringA, stringB);
不要使用String自带的方法stringA.compareTo("stringB")。反之,当需要使用非“本地化”的比较方法时,需要使用的是stringA.compareTo("stringB")