Java中HashMap,LinkedHashMap,TreeMap的区别

转载 2012年03月28日 16:49:39

http://hi.baidu.com/sleep651/blog/item/e42485a7490c799dd143582d.html

HashMap,LinkedHashMap,TreeMap都属于Map

Map 主要用于存储键(key)值(value)对,根据键得到值,因此键不允许键重复,但允许值重复。

HashMap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度。HashMap最多只允许一条记录的键为Null;允许多条记录的值为Null;HashMap不支持线程的同步,即任一时刻可以有多个线程同时写HashMap;可能会导致数据的不一致。如果需要同步,可以用Collections的synchronizedMap方法使HashMap具有同步的能力。
LinkedHashMap LinkedHashMap也是一个HashMap,但是内部维持了一个双向链表,可以保持顺序
TreeMap 不仅可以保持顺序,而且可以用于排序
HashMap例子:
    public static void main(String[] args) {
        Map<String, String> map = new HashMap<String, String>();
        map.put("a3", "aa");
        map.put("a2", "bb");
        map.put("b1", "cc");
        for (Iterator iterator = map.values().iterator(); iterator.hasNext();) {
            String name = (String) iterator.next();
            System.out.println(name);
        }
    }

LinkedHashMap例子:

    public static void main(String[] args) {
        Map<String, String> map = new LinkedHashMap<String, String>();
        map.put("a3", "aa");
        map.put("a2", "bb");
        map.put("b1", "cc");
        for (Iterator iterator = map.values().iterator(); iterator.hasNext();) {
            String name = (String) iterator.next();
            System.out.println(name);
        }
    }

TreeMap例子:

    public static void main(String[] args) {
        Map<String, String> map = new TreeMap<String, String>(new Comparator<Object>(){
            Collator collator = Collator.getInstance(); 
            public int compare(Object o1, Object o2) {
                CollationKey key1 = collator.getCollationKey(o1.toString());
                CollationKey key2 = collator.getCollationKey(o2.toString());
                return key1.compareTo(key2);
                //return collator.compare(o1, o2);
            }});
        map.put("a3", "aa");
        map.put("a2", "bb");
        map.put("b1", "cc");
        for (Iterator iterator = map.values().iterator(); iterator.hasNext();) {
            String name = (String) iterator.next();
            System.out.println(name);
        }
    }

运行这三个例子,体会一下它们之间的区别。


Java中HashMap,LinkedHashMap,TreeMap的区别

转载至:Java中HashMap,LinkedHashMap,TreeMap的区别Java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类,分别是HashMap Hashta...
  • IO_Field
  • IO_Field
  • 2016年11月22日 09:07
  • 3246

Java集合学习--HashMap、LinkedHashMap、TreeMap、HashTable

HashMap: 初始化: HashMap中有两个因子影响其性能:初始容量和加载因子。这两个参数都可以在创建时通过构造器传入,如果不指定,默认初始容量=16,加载因子=0.75,加载因子会影响reha...
  • yxinzju
  • yxinzju
  • 2015年08月19日 16:15
  • 832

hashMap,treeMap,LinkedHashMap使用以及区别分析

hashMap,treeMap,LinkedHashMap应用
  • chenpengfei1990
  • chenpengfei1990
  • 2016年11月28日 18:01
  • 740

【Java集合之Map】HashMap、HashTable、TreeMap、LinkedHashMap区别

前言ArrayList和LinkedList都实现了List接口,大致区别如下: ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。 对于随机访问get和se...
  • cyh1111
  • cyh1111
  • 2016年12月20日 13:03
  • 1178

HashMap和LinkedHashMapTreeMap的区别

HashMap,在Map 中插入、删除和定位元素,HashMap 是最好的选择。 如果要按自然顺序或自定义顺序遍历键,那么TreeMap会更好。 如果需要输出的顺序和输入的相同,那么用Linked...
  • wds1181977
  • wds1181977
  • 2016年06月21日 11:06
  • 558

HashMap,LinkedHashMap,TreeMap的区别

 Map主要用于存储健值对,根据键得到值,因此不允许键重复(重复了覆盖了),但允许值重复。Hashmap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很...
  • FG2006
  • FG2006
  • 2011年05月11日 10:35
  • 55060

java中HashMap,LinkedHashMap,TreeMap,HashTable的区别

java中HashMap,LinkedHashMap,TreeMap,HashTable的区别 java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类,分别是HashMa...
  • xiaodanjava
  • xiaodanjava
  • 2012年10月30日 09:12
  • 1990

HashMap和LinkedHashMap,TreeMap的区别

HashMap和LinkedHashMap,TreeMap的区别 1.具体区别如下: 我们在开发的过程中使用HashMap比较多,在Map中在Map 中插入、删除和定位元素,HashMap 是最好...
  • Lucky_bo
  • Lucky_bo
  • 2015年07月14日 16:57
  • 3292

HashMap,LinkedHashMap,TreeMap的区别

Map主要用于存储健值对,根据键得到值,因此不允许键重复(重复了覆盖了),但允许值重复。 Hashmap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有...
  • xin_jmail
  • xin_jmail
  • 2014年05月16日 14:23
  • 10436

TreeMap、HashMap、LindedHashMap的区别。

LinkedHashMap可以保证HashMap集合有序。存入的顺序和取出的顺序一致。TreeMap实现SortMap接口,能够把它保存的记录根据键排序,默认是按键值的升序排序,也可以指定排序的比较器...
  • m0_37721946
  • m0_37721946
  • 2017年10月31日 17:41
  • 172
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Java中HashMap,LinkedHashMap,TreeMap的区别
举报原因:
原因补充:

(最多只允许输入30个字)