java Collator类的具体用法场景

2024-06-09 02:18

本文主要是介绍java Collator类的具体用法场景,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Collator 用来简化我们处理各种语言之间的差别性。Collator 主要处理:

  • 规范化的典型等效 字符
  • 多层次的比较

通过比较字符串 Unicode 字节的 code point 来进行Java字符串的比较。这将意味着在Unicode代码图表字符位置指定的排序权重,但事实并非如此。语言可能有完全相同的字符而不同的排序权重。

例如,你完全不懂德语,你可能希望 ß (\u00DF) 被当作 b 或者 B 来进行排序,但事实上是 ss,在该语言中 ß 的排序值高于正常的 s。

而多层次的比较指的是提供4种比较级别:基本字符、口音、case、标点符号。

需要注意的是 Collator 不支持标点符号。

来看看一些具体的关于多层次比较例子的代码:

[Java]  view plain copy
  1. System.out.println("a equals b -> " + (collator.compare("a""b")==0 ? "true":"false"));  
  2. System.out.println("a equals à -> " + (collator.compare("a""à")==0 ? "true":"false"));  
  3. System.out.println("A equals a -> " + (collator.compare("a""A")==0 ? "true":"false"));  

 

当 collator.setStrength(Collator.PRIMARY):

a equals b -> false
a equals à -> true
A equals a -> true

当 collator.setStrength(Collator.SECONDARY):

a equals b -> false
a equals à -> false
A equals a -> true

当 collator.setStrength(Collator.TERTIARY):

a equals b -> false
a equals à -> false
A equals a -> false

还有下面这段代码,尽管第一行输出的是 false ,但是他们看起来确实完全相同的字符串:

[Java]  view plain copy
  1. collator.setDecomposition(Collator.CANONICAL_DECOMPOSITION);  
  2. String single = "abgaskr\u00FCmmerdichtung";  
  3. String combined = "abgaskr\u0075\u0308mmerdichtung";  
  4.   
  5. System.out.println("Single equals combined? " +   
  6.     (collator.compare(single, combined) == 0 ? "true""false"));  

等等,种子 Collator 类理解起来挺费劲,但当你需要处理各种不同语言时,你还真离不开它。

你可以从这里查看 Collator 类的 JavaDoc 文档。

[java]  view plain copy
  1. protected List<Map<String, Object>> getData(String prefix) {  
  2.         List<Map<String, Object>> myData = new ArrayList<Map<String, Object>>();  
  3.   
  4.         Intent mainIntent = new Intent(Intent.ACTION_MAIN, null);  
  5.         mainIntent.addCategory("com.actionbarsherlock.sample.demos.EXAMPLE");  
  6.   
  7.         PackageManager pm = getPackageManager();  
  8.         List<ResolveInfo> list = pm.queryIntentActivities(mainIntent, 0);  
  9.   
  10.         if (null == list)  
  11.             return myData;  
  12.   
  13.         String[] prefixPath;  
  14.         String prefixWithSlash = prefix;  
  15.   
  16.         if (prefix.equals("")) {  
  17.             prefixPath = null;  
  18.         } else {  
  19.             prefixPath = prefix.split("/");  
  20.             prefixWithSlash = prefix + "/";  
  21.         }  
  22.   
  23.         int len = list.size();  
  24.   
  25.         Map<String, Boolean> entries = new HashMap<String, Boolean>();  
  26.   
  27.         for (int i = 0; i < len; i++) {  
  28.             ResolveInfo info = list.get(i);  
  29.             CharSequence labelSeq = info.loadLabel(pm);  
  30.             String label = labelSeq != null  
  31.                     ? labelSeq.toString()  
  32.                     : info.activityInfo.name;  
  33.   
  34.             if (prefixWithSlash.length() == 0 || label.startsWith(prefixWithSlash)) {  
  35.   
  36.                 String[] labelPath = label.split("/");  
  37.   
  38.                 String nextLabel = prefixPath == null ? labelPath[0] : labelPath[prefixPath.length];  
  39.   
  40.                 if ((prefixPath != null ? prefixPath.length : 0) == labelPath.length - 1) {  
  41.                     addItem(myData, nextLabel, activityIntent(  
  42.                             info.activityInfo.applicationInfo.packageName,  
  43.                             info.activityInfo.name));  
  44.                 } else {  
  45.                     if (entries.get(nextLabel) == null) {  
  46.                         addItem(myData, nextLabel, browseIntent(prefix.equals("") ? nextLabel : prefix + "/" + nextLabel));  
  47.                         entries.put(nextLabel, true);  
  48.                     }  
  49.                 }  
  50.             }  
  51.         }  
  52.   
  53.         Collections.sort(myData, sDisplayNameComparator);  
  54.   
  55.         return myData;  
  56.     }  
  57.   
  58.     private final static Comparator<Map<String, Object>> sDisplayNameComparator =  
  59.         new Comparator<Map<String, Object>>() {  
  60.         private final Collator   collator = Collator.getInstance();  
  61.   
  62.         public int compare(Map<String, Object> map1, Map<String, Object> map2) {  
  63.             return collator.compare(map1.get("title"), map2.get("title"));  
  64.         }  
  65.     };  

这篇关于java Collator类的具体用法场景的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043978

相关文章

SpringBoot实现RSA+AES自动接口解密的实战指南

《SpringBoot实现RSA+AES自动接口解密的实战指南》在当今数据泄露频发的网络环境中,接口安全已成为开发者不可忽视的核心议题,RSA+AES混合加密方案因其安全性高、性能优越而被广泛采用,本... 目录一、项目依赖与环境准备1.1 Maven依赖配置1.2 密钥生成与配置二、加密工具类实现2.1

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

C语言中%zu的用法解读

《C语言中%zu的用法解读》size_t是无符号整数类型,用于表示对象大小或内存操作结果,%zu是C99标准中专为size_t设计的printf占位符,避免因类型不匹配导致错误,使用%u或%d可能引发... 目录size_t 类型与 %zu 占位符%zu 的用途替代占位符的风险兼容性说明其他相关占位符验证示

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比