package com.yputil.util;

import java.text.CollationKey;
import java.text.Collator;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

/**
* 按中文排序
*
* @author Administrator 时间:2017.8.22 PM
*/
public class ChineseSortUtil implements Comparator<Object> {

public ChineseSortUtil() {
}

public static boolean sortType = true;

private Collator coll = Collator.getInstance();// 查看中文api详解

@Override
public int compare(Object arg0, Object arg1) {

// 要想不区分大小写进行比较用o1.toString().toLowerCase()
CollationKey key1 = coll.getCollationKey(arg0.toString());
CollationKey key2 = coll.getCollationKey(arg1.toString());

// 降序加个"-"
if(sortType) //升序
return key1.compareTo(key2);
else
return -key1.compareTo(key2); //降序
}

/**
* 排序 1.Map 2.简单数组 3.List
*
* 根据中文字符排序
* sortType : true--升序 false--降序
* obj : 排序的对象
* 目前对Map没作用
*/
public static Object sortByChinese(Object obj,boolean sortType) {
ChineseSortUtil.sortType = sortType;
// Object objRet = null;
if (obj instanceof Map) { // map
mapSort((Map) obj);
} else if (obj instanceof List) { // List
listSort((List) obj);
} else if (obj instanceof String[]) { // String[] 数组
stringsSort((String[]) obj);
}
return obj;
}

/**
* strs 数组
*
* @param strs
*/
private static void stringsSort(String[] strs) {
Comparator<Object> com = Collator.getInstance(java.util.Locale.CHINA);
Arrays.sort(strs, com);
}

/**
* 说明:因为ArrayList实现的是RandomAccess 随机访问接口。使用get()要比迭代的效率高。
* 如果实现的是SequenceAccess(顺序访问接口。如:LinkList),使用迭代的效率高
*
* @param list
*/
private static void listSort(List list) {
ChineseSortUtil comparator = new ChineseSortUtil();
Collections.sort(list, comparator);
}

private static void mapSort(Map map) {
// 按照键值排序
ChineseSortUtil comparator = new ChineseSortUtil();
// 注意:每次对TreeMap进行put()时,TreeMap都会自动调用它的compare(key,Entry.key)
// 按照key进行排序
Collection col = map.keySet();
Iterator it = col.iterator();
/*
* while (it.hasNext()) { System.out.println(it.next()); }
*/

}

}

java中文拼音字母排序的更多相关文章

  1. MySQL、Oracle、DB2等数据库常规排序、自定义排序和按中文拼音字母排序

    MySQL常规排序.自定义排序和按中文拼音字母排序,在实际的SQL编写时,我们有时候需要对条件集合进行排序. 下面给出3中比较常用的排序方式,mark一下 1.常规排序ASC DESC ASC 正序 ...

  2. Java对中文进行排序

    对中文进行排序,同样是得定义一个Comparator,下面上代码: import java.text.Collator; import java.util.ArrayList; import java ...

  3. Android实现中文汉字笔划(笔画)、中文拼音排序、英文排序

    发布时间:2018-11-16   技术:Android   概述 最近要做一个类似微信的,在登录界面选择国家地区的功能,微信有中文汉字笔画排序以及中文拼音排序等几种方式,如下所示: 简体中文 拼音排 ...

  4. Java TreeMap的排序

    TreeMap 和 HashMap 用法大致相同,但实际需求中,我们需要把一些数据进行排序:以前在项目中,从数据库查询出来的数据放在List中,顺序都还是对的,但放在HashMap中,顺序就完全乱了. ...

  5. java中文乱码解决之道(一)-----认识字符集

    沉寂了许久(大概有三个多月了吧),LZ"按捺不住"开始写博了! java编码中的中文问题是一个老生常谈的问题了,每次遇到中文乱码LZ要么是按照以前的经验修改,要么则是baidu.c ...

  6. java中文乱码解决之道(九)-----总结

    乱码,我们前台展示的杀手,可能有些朋友和我的经历一样:遇到乱码先按照自己的经验来解决,如果没有解决就google,运气好一搜就可以解决,运气不好可能够你折腾一番了.LZ之所以写这个系列博客就是因为遇到 ...

  7. Java 中文乱码问题总结

    开发java应用出现乱码是很常见的,毕竟现在unicode的使用还不是很广泛,在使用gb2312(包含了gbk简体,big5繁体)的系统中要正确 实现中文的display和数据库的存储是最基本的要求. ...

  8. java中文乱码解决之道(二)-----字符编码详解:基础知识 + ASCII + GB**

    在上篇博文(java中文乱码解决之道(一)-----认识字符集)中,LZ简单介绍了主流的字符编码,对各种编码都是点到为止,以下LZ将详细阐述字符集.字符编码等基础知识和ASCII.GB的详情. 一.基 ...

  9. java中文乱码解决之道(七)-----JSP页面编码过程

    我们知道JSP页面是需要转换为servlet的,在转换过程中肯定是要进行编码的.在JSP转换为servlet过程中下面一段代码起到至关重要的作用. <%@ page language=" ...

随机推荐

  1. linux下连接windows的远程桌面

    拿ubuntu来举例: 1安装rdesktop 2 rdesktop -f 196.168.1.11:3389 3 哦鸟

  2. iOS视图控制器初始化问题

    最近在群里见不少人 问到用视图控制器的alloc /init方法初始化的时候,出来的是黑色的空界面.之前我也遇到过,所以在这里总结下. 我们在项目中肯定都会用到自定义的ViewController,而 ...

  3. 理解WebKit和Chromium: Chromium WebView和Chrome浏览器渲染机制

    转载请注明原文地址:http://blog.csdn.net/milado_nju ## 数据对比 前面介绍过Chromium WebView的时候,说过有关ChromiumWebView同Chrom ...

  4. PHP(PHP-FPM)手动编译安装

    1安装PHP 1.1下载解压 wget http://museum.php.net/php5/php-5.3.5.tar.gz tarxzvf php-5.3.5.tar.gz cdphp-5.3.5 ...

  5. [GitHub]第八讲:GitHub Pages

    Github Pages 是 github 公司提供的免费的静态网站托管服务,用起来方便而且功能强大,不仅没有空间限制,还可以绑定自己的域名.在 https://pages.github.com/ 首 ...

  6. 【unix网络编程第三版】ubuntu端口占用问题

    <unix网络编程>一书中的代码并不是能直接运行,有时候需要结合各方面的知识来解决,大家在这本书的时候,一定要把代码都跑通,不难你会错过很多学习的机会! 1.问题描述 本人在阅读<U ...

  7. 为什么很多类甚者底层源码要implements Serializable ?

    为什么很多类甚者底层源码要implements Serializable ? 在碰到异常类RuntimeException时,发现Throwable实现了 Serializable,还有我们平进的ja ...

  8. [C++学习历程]基础部分 C++中的指针数组和结构

    作者:苏生米沿 本文地址:http://blog.csdn.net/sushengmiyan/article/details/19938177 一.指针 对学习C++来说,指针是一项重要内容,以前,教 ...

  9. 基于java自身技术实现消息方式的系统间通信

    这篇博客基本照搬了分布式java应用基础与实践一书的内容 java自带的远程调用分两种一种是rmi,一种是webservice 我们先看rmi(remote method invoke)# 使用rmi ...

  10. 从JDK源码角度看并发竞争的超时

    JDK中的并发框架提供的另外一个优秀机制是锁获取超时的支持,当大量线程对某一锁竞争时可能导致某些线程在很长一段时间都获取不了锁,在某些场景下可能希望如果线程在一段时间内不能成功获取锁就取消对该锁的等待 ...