java中HashMap,LinkedHashMap,TreeMap,HashTable的区别 :
java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类,分别是HashMap Hashtable LinkedHashMap 和TreeMap 
Map主要用于存储健值对,根据键得到值,因此不允许键重复(重复了覆盖了),但允许值重复。 Hashmap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度,遍历时,取得数据的顺序是完全随机的。HashMap最多只允许一条记录的键为Null;允许多条记录的值为 Null;HashMap不支持线程的同步,即任一时刻可以有多个线程同时写HashMap;可能会导致数据的不一致。如果需要同步,可以用 Collections的synchronizedMap方法使HashMap具有同步的能力,或者使用ConcurrentHashMap。 
Hashtable与 HashMap类似,它继承自Dictionary类,不同的是:它不允许记录的键或者值为空;它支持线程的同步,即任一时刻只有一个线程能写Hashtable,因此也导致了 Hashtable在写入时会比较慢。

LinkedHashMap保存了记录的插入顺序,在用Iterator遍历LinkedHashMap时,先得到的记录肯定是先插入的.也可以在构造时用带参数,按照应用次数排序。在遍历的时候会比HashMap慢,不过有种情况例外,当HashMap容量很大,实际数据较少时,遍历起来可能会比LinkedHashMap慢,因为LinkedHashMap的遍历速度只和实际数据有关,和容量无关,而HashMap的遍历速度和他的容量有关。 
TreeMap实现SortMap接口,能够把它保存的记录根据键排序,默认是按键值的升序排序,也可以指定排序的比较器,当用Iterator 遍历TreeMap时,得到的记录是排过序的。 
一般情况下,我们用的最多的是HashMap,HashMap里面存入的键值对在取出的时候是随机的,它根据键的HashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度。在Map 中插入、删除和定位元素,HashMap 是最好的选择。

TreeMap取出来的是排序后的键值对。但如果您要按自然顺序或自定义顺序遍历键,那么TreeMap会更好。 
LinkedHashMap 是HashMap的一个子类,如果需要输出的顺序和输入的相同,那么用LinkedHashMap可以实现,它还可以按读取顺序来排列,像连接池中可以应用。以下代码实例可以看出HashMap,LinkedHashMap,TreeMap的区别:

 
package zhishidian.hashmap;

import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map.Entry;
import java.util.Set;
import java.util.TreeMap; public class MapDemo {
public static void main(String[] args) {
// HashMap
System.out.println("------HashMap无序输出------");
HashMap<String, String> hsMap = new HashMap<String, String>();
hsMap.put("3", "Value3");
hsMap.put("1", "Value1");
hsMap.put("2", "Value2");
hsMap.put("b", "ValueB");
hsMap.put("a", "ValueA"); Set<Entry<String, String>> set1 = hsMap.entrySet();
Iterator<Entry<String, String>> it1 = set1.iterator();
while (it1.hasNext()) {
Entry<String, String> entry1 = it1.next();
String key1 = entry1.getKey();
String value1 = entry1.getValue();
System.out.println("Key: " + key1 + "--Value: " + value1);
}
// TreeMap
System.out.println("------TreeMap按Key排序输出------");
TreeMap<String, String> trMap = new TreeMap<String, String>();
trMap.put("3", "Value3");
trMap.put("1", "Value1");
trMap.put("2", "Value2");
trMap.put("b", "ValueB");
trMap.put("a", "ValueA");
Set<Entry<String, String>> set2 = trMap.entrySet();
Iterator<Entry<String, String>> it2 = set2.iterator();
while (it2.hasNext()) {
Entry<String, String> entry2 = it2.next();
String key2 = entry2.getKey();
String value2 = entry2.getValue(); System.out.println("Key: " + key2 + "--Value: " + value2);
}
// LinkedHashMap
System.out.println("--LinkedHashMap根据输入的顺序输出--");
LinkedHashMap<String, String> lkMap = new LinkedHashMap<String, String>();
lkMap.put("3", "Value3");
lkMap.put("1", "Value1");
lkMap.put("2", "Value2");
lkMap.put("b", "ValueB");
lkMap.put("a", "ValueA");
Set<Entry<String, String>> set3 = lkMap.entrySet();
Iterator<Entry<String, String>> it3 = set3.iterator();
while (it3.hasNext()) {
Entry<String, String> entry3 = it3.next();
String key3 = entry3.getKey();
String value3 = entry3.getValue();
System.out.println("Key: " + key3 + "--Value: " + value3);
}
}
}
// ------HashMap无序输出------
// Key: 3--Value: Value3
// Key: 2--Value: Value2
// Key: 1--Value: Value1
// Key: b--Value: ValueB
// Key: a--Value: ValueA
// ------TreeMap按Key排序输出------
// Key: 1--Value: Value1
// Key: 2--Value: Value2
// Key: 3--Value: Value3
// Key: a--Value: ValueA
// Key: b--Value: ValueB
// --LinkedHashMap根据输入的顺序输出--
// Key: 3--Value: Value3
// Key: 1--Value: Value1
// Key: 2--Value: Value2
// Key: b--Value: ValueB
// Key: a--Value: ValueA

最新文章

  1. 阿里2014校招笔试题(南大)——利用thread和sleep生成字符串的伪随机序列
  2. scrollWidth的巧妙运用
  3. curl常用操作
  4. 二:ZooKeeper术语概念
  5. oj放苹果
  6. [Canvas] Make Canvas Responsive to Pixel Ratio
  7. hdu 3333 树状数组
  8. SharePoint 2010 出错! HTTP Error 503. The service is unavailable
  9. Android的Spinner
  10. JDK版本过高,导致Eclipse报错
  11. HDU 5224 Tom and paper(最小周长)
  12. HTML5中class选择器属性的解释
  13. IM 融云 之 开发基础概念
  14. JSON.parse()和JSON.stringify()和eval(&#39;(&#39; + result + &#39;)&#39;)
  15. JSON Web Token - 在Web应用间安全地传递信息
  16. asp.net core系列 60 Ocelot 构建服务认证示例
  17. [翻译] Oracle Database 12c 新特性Multitenant
  18. 云数据库POLARDB优势解读之①——10分钟了解
  19. Two distinct points CodeForces - 1108A (签到)
  20. mybatis #与$区别

热门文章

  1. Django db使用MySQL连接池
  2. MyCms 自媒体 CMS 系统 v2.7,支持自定义页面
  3. gin中自定义路由日志的格式
  4. 云原生新时代弄潮儿k8s凭什么在容器化方面独树一帜?
  5. 如何快速写出高质量的 Go 代码?
  6. 多种方式告诉你如何计算DM同步数据到TiDB的延时时间
  7. freeswitch插件式模块接口实现方式
  8. Swift循环的介绍
  9. Shell编程中的用户输入处理
  10. JScrollPane 自动跟进 自动到滚动到最底部