JAVA SortedMap接口
SortedMap接口主要提供有序的Map实现。
Map的主要实现有HashMap,TreeMap,HashTable,LinkedHashMap。
TreeMap实现了SortedMap接口,保证了有序性。默认的排序是根据key值进行升序排序,也可以重写comparator方法来根据value进行排序。
HashMap与TreeMap的比较
-
public class SortedMapTest2 {
-
-
public static void main(String[] args) {
-
-
Map<String,Object> hashMap = new HashMap<String,Object>();
-
hashMap.put("1", "a");
-
hashMap.put("5", "b");
-
hashMap.put("2", "c");
-
hashMap.put("4", "d");
-
hashMap.put("3", "e");
-
Set<Entry<String, Object>> entry = hashMap.entrySet();
-
for(Entry<String, Object> temp : entry){
-
System.out.println("hashMap:"+temp.getKey()+" 值"+temp.getValue());
-
}
-
-
System.out.println("\n");
-
-
SortedMap<String,Object> sortedMap = new TreeMap<String,Object>();
-
sortedMap.put("1", "a");
-
sortedMap.put("5", "b");
-
sortedMap.put("2", "c");
-
sortedMap.put("4", "d");
-
sortedMap.put("3", "e");
-
Set<Entry<String, Object>> entry2 = sortedMap.entrySet();
-
for(Entry<String, Object> temp : entry2){
-
System.out.println("sortedMap:"+temp.getKey()+" 值"+temp.getValue());
-
}
-
-
}
-
-
}
运算的结果为
-
hashMap:1 值a
-
hashMap:2 值c
-
hashMap:3 值e
-
hashMap:4 值d
-
hashMap:5 值b
-
-
sortedMap:1 值a
-
sortedMap:2 值c
-
sortedMap:3 值e
-
sortedMap:4 值d
-
sortedMap:5 值b
看上去还以为HashMap也保证了有序性,其实是随机的,如果值设置的复杂一点,如下例:
-
public class SortedMapTest3 {
-
-
public static void main(String[] args) {
-
-
Map<String,Object> hashMap = new HashMap<String,Object>();
-
hashMap.put("1b", "a");
-
hashMap.put("2", "b");
-
hashMap.put("4b", "d");
-
hashMap.put("3", "c");
-
hashMap.put("2b", "d");
-
hashMap.put("3b", "c");
-
Set<Entry<String, Object>> entry = hashMap.entrySet();
-
for(Entry<String, Object> temp : entry){
-
System.out.println("hashMap:"+temp.getKey()+" 值"+temp.getValue());
-
}
-
-
System.out.println("\n");
-
-
SortedMap<String,Object> sortedMap = new TreeMap<String,Object>();
-
sortedMap.put("1b", "a");
-
sortedMap.put("2", "b");
-
sortedMap.put("4b", "d");
-
sortedMap.put("3", "c");
-
sortedMap.put("2b", "d");
-
sortedMap.put("3b", "c");
-
Set<Entry<String, Object>> entry2 = sortedMap.entrySet();
-
for(Entry<String, Object> temp : entry2){
-
System.out.println("sortedMap:"+temp.getKey()+" 值"+temp.getValue());
-
}
-
-
}
-
-
}
运算的结果是:
-
hashMap:2b 值d
-
hashMap:1b 值a
-
hashMap:2 值b
-
hashMap:3 值c
-
hashMap:4b 值d
-
hashMap:3b 值c
-
-
sortedMap:1b 值a
-
sortedMap:2 值b
-
sortedMap:2b 值d
-
sortedMap:3 值c
-
sortedMap:3b 值c
-
sortedMap:4b 值d
很显然只有TreeMap保证了有序性。
那如果想要根据value值来进行排序
-
public class SortedMapTest {
-
-
public static void main(String[] args) {
-
-
SortedMap<String,String> sortedMap = new TreeMap<String,String>();
-
sortedMap.put("1", "a");
-
sortedMap.put("5", "b");
-
sortedMap.put("2", "c");
-
sortedMap.put("4", "d");
-
sortedMap.put("3", "e");
-
Set<Entry<String, String>> entry2 = sortedMap.entrySet();
-
for(Entry<String, String> temp : entry2){
-
System.out.println("修改前 :sortedMap:"+temp.getKey()+" 值"+temp.getValue());
-
}
-
System.out.println("\n");
-
-
//这里将map.entrySet()转换成list
-
List<Map.Entry<String,String>> list =
-
new ArrayList<Map.Entry<String,String>>(entry2);
-
-
Collections.sort(list, new Comparator<Map.Entry<String,String>>(){
-
-
@Override
-
public int compare(Entry<String, String> o1, Entry<String, String> o2) {
-
// TODO Auto-generated method stub
-
return o1.getValue().compareTo(o2.getValue());
-
}
-
-
});
-
-
for(Map.Entry<String,String> temp :list){
-
System.out.println("修改后 :sortedMap:"+temp.getKey()+" 值"+temp.getValue());
-
}
-
}
-
-
}
运行结果为:
-
修改前 :sortedMap:1 值a
-
修改前 :sortedMap:2 值c
-
修改前 :sortedMap:3 值e
-
修改前 :sortedMap:4 值d
-
修改前 :sortedMap:5 值b
-
-
修改后 :sortedMap:1 值a
-
修改后 :sortedMap:5 值b
-
修改后 :sortedMap:2 值c
-
修改后 :sortedMap:4 值d
-
修改后 :sortedMap:3 值e
JAVA SortedMap接口的更多相关文章
- Java 数据类型:集合接口Map:HashTable;HashMap;IdentityHashMap;LinkedHashMap;Properties类读取配置文件;SortedMap接口和TreeMap实现类:【线程安全的ConcurrentHashMap】
Map集合java.util.Map Map用于保存具有映射关系的数据,因此Map集合里保存着两个值,一个是用于保存Map里的key,另外一组值用于保存Map里的value.key和value都可以是 ...
- SortedMap接口:进行排序操作。
回顾:SortedSet是TreeSet的实现接口,此接口可以排序. SortedMap接口同样可以排序,是TreeMap的实现接口,父类. 定义如下: public class TreeMap< ...
- SortedMap接口的实现类TreeMap介绍和实现Comparator自定义比较器(转)
与SortedSet接口类似,SortedMap也是一个结构,待排序的Map,其一个比较常用的实现类是TreeMap. TreeMap的put(K key, V value)方法在每添加一个元素时,都 ...
- SortedMap接口
SortedMap接口是排序接口,只要是实现了此接口的子类,都属于排序的子类,TreeMap也是此接口的一个子类. import java.util.Map; import java.util.Sor ...
- 深入理解Java的接口和抽象类(转)
深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的 ...
- 深入理解Java的接口和抽象类
深入理解Java的接口和抽象类 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太多不同的地方.很多人在初学的 ...
- java微信接口之五—消息分组群发
一.微信消息分组群发接口简介 1.请求:该请求是使用post提交地址为: https://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_t ...
- java微信接口之四—上传素材
一.微信上传素材接口简介 1.请求:该请求是使用post提交地址为: https://api.weixin.qq.com/cgi-bin/media/uploadnews?access_token=A ...
- android 学习随笔二十七(JNI:Java Native Interface,JAVA原生接口 )
JNI(Java Native Interface,JAVA原生接口) 使用JNI可以使Java代码和其他语言写的代码(如C/C++代码)进行交互. 问:为什么要进行交互? 首先,Java语言提供的类 ...
随机推荐
- JS中的发布订阅模式
一. 你是如何理解发布订阅模式的 JS中的设计模式: 单例模式:处理业务逻辑 构造原型模式:封装类库,组件,框架,插件等 类库:jQuery 只是提供了一些常用的方法,可以应用到任何的项目中,不具备业 ...
- web服务器软件(Nginx,Apache,IIS,Lighttpd)介绍
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行.其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在 ...
- java中Arrays类的应用
java.util.Arrays类能方便地操作数组,它提供的所有方法都是静态的.具有以下功能: ² 给数组赋值:通过fill方法. ² 对数组排序:通过sort方法,按升序. ² 比较数组:通过equ ...
- Java FutureTask Example Program(Java FutureTask例子)
Sometime back I wrote a post about Java Callable Future interfaces that we can use to get the concur ...
- C#学习笔记——常量、字段以及事件
一 常量与字段 (一) 常量 常量总是被视为静态成员,而不是实例成员.定义常量将导致创建元数据.代码引用一个常量时,编译器会在定义常量的程序集的元数据中查找该符号,提取常量的值,并将值嵌入IL中.由于 ...
- php课程 9-33 php文件操作里面的注意事项有哪些
php课程 9-33 php文件操作里面的注意事项有哪些 一.总结 一句话总结:文件操作其实很简单,就是几个文件操作函数需要记一下. 1.文件函数如何使用(如何找php文件函数的资料)? 查看参考手册 ...
- php杂项函数
php杂项函数 一.总结 看着函说作用 函数 描述 PHP constant() 返回一个常量的值. 4 define() 定义一个常量. 3 defined() 检查某常量是否存在. 3 d ...
- shell脚本一键安装mysql5.7.x
使用脚本一键安装mysql5.7.x,初始化数据库.启动数据库---- mysql版本号:源代码mysql5.7.10 linux版本号:centos6.5 x86_64 #!/bin/bash GR ...
- 英特尔投资:7200万美元投资12家创新公司,包括3家中国公司(www.intelcapital.com)
集微网消息,英特尔投资——英特尔公司全球投资机构,今天在英特尔投资全球峰会上宣布向12家科技创业公司投资超过7200万美元.加上今天宣布的新投资,英特尔投资在2018年投资总额已超过1.15亿美元. ...
- debian 下的vi 上下左右键问题
小白一只,查了一下vi的版本信息 发现好像是vim 于是把~/.vimrc 变量设置了一下就好了。 将set compatible 设置成set nocompatible . 这是因为系统会默认vim ...