最近工作遇到需要按一个model中不同的列进行排序的问题,查了一下JDK API文档,发现,java
中可以排序的工具类和接口共有五个SortedMap 、SortedSet、TreeMap 、TreeSet和Collections,由于我要排序的是一系列model,所以,最后使用了TreeMap对象,而且TreeMap到最后的处理比较自由,可以直接返回TreeMap对象,也可以返回model的一个Collection对象。其它几个类的用法其实都是大同小异,如果java
基础较好,看一下API文档很容易明白,只是Collection中需要显式调用sort()方法而已
写理论的东西或者深入的东西就会太多了,而且让人会看得比较烦,这里讲求实用,就不多说了,直接入正体,基本的排序代码如下:
package ChineseSort;
import java
.util.Collection;
import java
.util.Iterator;
import java
.util.SortedMap;
import java
.util.TreeMap;
/**
* @author chenlei
*/
public class TestSort {
public static void main(String[] args) {
??? // TODO Auto-generated method stub???
??? TreeMap map
= new TreeMap();?????
??? for(int i=0; i<10; i++) {
??????? String s = ""+(int)(Math.random()*1000);
??????? map
.put(s,s);
??? }
??? map
.put("abcd","abcd");
??? map
.put("Abc", "Abc");
??? map
.put("bbb","bbb");
??? map
.put("BBBB", "BBBB");
??? map
.put("北京","北京");
??? map
.put("中国","中国");
??? map
.put("上海", "上海");
??? map
.put("厦门", "厦门");
??? map
.put("香港", "香港");
??? map
.put("碑海", "碑海");
??? Collection col = map
.values();
??? Iterator it = col.iterator();
??? while(it.hasNext()) {
??????? System.out.println(it.next());}}}
??? 代码就不多作解释了,一看就明白,开始放进去10个整数随机数,然后是英文,然后是中文。运行结果如下:
132
205
287
295
39
410
411
464
670
73
Abc
BBBB
abcd
bbb
上海
中国
北京
厦门
碑海
香港
注意,这里的数字排序正常,而英文排序是区分大小写的,这个也是正常的,因为ASCII码中小写字母比大写字母靠后,中文排序则明显的不正确,碑和北明显应该在一起的,而且应该在最前面。这个主要是java
中使用中文编码GB2312或者JBK时,char型转换成int型得过程出现了比较大的偏差,很多文章介绍过了,大家可以去网上找一下,这里不多说了,直接寻找解决方案
?????? Java
中之所以出现偏差,主要是compare方法的问题,所以这里自己实现Comparator接口,而国际化的问题,使用Collator类来解决。这里先解决中文问题,代码如下:
package ChineseSort;
import java
.text.CollationKey;
import java
.text.Collator;
import java
.util.Comparator;
/**
* @author chenlei
*/
public class CollatorComparator implements Comparator {
Collator collator = Collator.getInstance();
public int compare(Object element1, Object element2) {
??? CollationKey key1 = collator.getCollationKey(element1.toString());
??? CollationKey key2 = collator.getCollationKey(element2.toString());
??? return key1.compareTo(key2);
}
}
?????? 同时修改我们前面完成的TestSort类,找到
??? TreeMap map
= new TreeMap();
??? 修改为
??? CollatorComparator comparator = new CollatorComparator();
??? TreeMap map
= new TreeMap(comparator);
??? 再次运行该类,运行结果如下:
325
62
653
72
730
757
874
895
909
921
Abc
abcd
bbb
BBBB
碑海
北京
上海
厦门
香港
中国
?????? 此时可以看到中文的排序已经完成正常。如果想不让英文区分大小写,则修改CollatorComparator类,找到
??? element1.toString()
??? 修改为:
??? element1.toString().toLowerCase()
??? 当然你改成转换成大写的也无所谓了,当然element2.toString()也要同时修改为element2.toString().toLowerCase()。再次运行结果如下:
207
353
656
659
770
789
857
861
931
984
Abc
abcd
bbb
BBBB
碑海
北京
上海
厦门
香港
中国
???现在可以看到,排序已经完全符合我们的要求了。如果要反向排序也很容易,遍历的时候倒过来,或者你写两个Comparator的实现类,正向的排序就像我们前面所写的,反向排序就将return key1.compareTo(key2);修改成return -key1.compareTo(key2);,加了个负号,这里你可以直接加个符号看看效果,结果我就不写了,肯定中国是Number One。我还真没找到TreeMap里直接反向的方法,谁看到了告诉我。
转自:http://www.24xuexi.com/w/2011-05-30/90641.html
分享到:
相关推荐
ECharts 是百度开发的一个基于 JavaScript 的数据可视化库,它提供了丰富的图表类型,包括柱状图、折线图、饼图以及我们关注的 TreeMap。TreeMap 是一种用以表示层次结构数据的可视化方式,通过不同大小的矩形来展示...
在Java编程语言中,`TreeMap` 是一个有序的键值对集合,它实现了 `SortedMap` 接口。这个数据结构内部基于红黑树(Red-Black Tree)算法实现,保证了插入、删除和查找操作的时间复杂度为 O(log n)。在“java treemap...
### Java中HashMap, LinkedHashMap, TreeMap,HashTable的区别 在Java编程语言中,`Map`接口是集合框架中的一个重要组成部分,用于存储键值对。本文将详细分析四种常用的`Map`实现类:`HashMap`, `LinkedHashMap`, ...
**C# TreeMap与Sunburst算法详解** 在信息可视化领域,数据的呈现方式至关重要,它能够帮助我们更好地理解和分析复杂的数据结构。C#编程语言提供了多种工具和库来实现这一目标,其中Treemap和Sunburst是两种非常...
在Java编程中,Map接口是用于存储键值对的数据结构,而Java提供了多种Map的实现,包括TreeMap、HashMap和ConcurrentSkipListMap。本文主要比较了这三种Map的性能,尤其是在插入和查找操作上的效率。 1. **TreeMap**...
在Java编程中,TreeMap是一种基于红黑树(Red-Black Tree)算法实现的有序映射数据结构。它按照键的自然顺序或者自定义比较器的顺序来存储元素。在这个场景下,`TreeMap`被用来实现数据的分组,并构建一个树形结构,...
**DataV-TreeMap示例** DataV是阿里巴巴开源的一款数据可视化工具,它提供了一系列丰富的图表组件,帮助企业或个人快速构建数据展示应用。在DataV中,TreeMap是一种以矩形树状结构来展示层次数据的可视化方法。这种...
这个程序基于`Treemap`数据结构,这是一种在Java中由`java.util.TreeMap`类提供的有序映射,它允许以键值对的形式存储数据,并且能保持键的自然排序或者自定义排序。 `Treemap`的主要特点: 1. **有序性**:`...
Java TreeMap统计单词出现的次数 Java TreeMap是一个有序的Map实现,它可以根据对象的自然顺序或自定义的比较器对键进行排序。在本例中,我们使用TreeMap来统计一个句子或一个段落中单词出现的次数,并按照字母表...
本主题聚焦于使用Python的TreeMap进行数据可视化。TreeMap是一种多层嵌套的矩形图,根据数据大小来分配矩形的面积,使得整体布局紧凑且直观。在Python中,我们可以借助Matplotlib库或专门的可视化库如squarify来实现...
Java 中的 Map、HashMap、TreeMap 使用详解 Map 是 Java 集合框架中的一个接口,用于存储键值对,根据键可以获取值。Map 中的键不允许重复,但值可以重复。在 Java 中,HashMap、LinkedHashMap、TreeMap 都实现了 ...
TreeMap是一种有效的数据可视化方法,尤其适用于展示层次结构数据或比较不同类别的相对大小。在这个案例中,我们将探讨如何使用Python中的`Matplotlib`库来实现TreeMap,同时利用提供的`products.csv`, `aisles.csv`...
Java TreeMap是一种基于红黑树实现的Map接口的Map,它为存储键值对提供了一个有序的集合。TreeMap与HashMap不同的是,TreeMap的元素是根据键的自然排序或通过Comparator提供的排序来维护键的有序性。TreeMap提供了对...
在Java编程语言中,集合框架提供了多种数据结构来存储和操作数据,其中`TreeMap`、`TreeSet`、`HashSet`以及`HashMap`是最常用的数据结构之一。这些集合类各自有着独特的特性和应用场景,下面将对它们进行详细介绍。...
TreeMap是一种数据结构,它是Java集合框架的一部分,位于`java.util`包中。它实现了一个映射接口,其中键(keys)是唯一的,并且通过自然排序或者自定义比较器进行排序。TreeMap内部使用红黑树算法来维护键值对的...
TreeMap是Java集合框架中的一种有序映射数据结构,它实现了SortedMap接口,提供了按自然顺序或自定义比较器顺序存储键值对的能力。在深入理解TreeMap的源码之前,我们首先要了解其背后的基石——红黑树。 红黑树...
在Java编程语言中,`TreeSet`和`TreeMap`是两种基于红黑树数据结构的集合类,它们都属于`java.util`包。这两个类主要用于存储有序的数据,因此它们在内部实现上需要进行比较操作,这就导致了它们对`null`值的特殊...
van Wijk 发布的 Squarified Treemap 算法。 用途 假设我们有一个宽度为 6、高度为 4 的矩形,并且进一步假设这个矩形必须细分为 7 个矩形,面积分别为 6、6、4、3、2、2 和 1。标准树形图算法使用一个简单的方法...
TreeMap按VALUE排序
编写一个应用程序,使用TreeMap,V>类,分别按照价格和容量排序并输出10个硬盘的详细信息 9_5.编写一个应用程序,要求将LinkedList创建的对象写入到文件,然后读出一个LinkedList对象,并遍历LinkedList节点中的数据