zoukankan      html  css  js  c++  java
  • HashTable, HashMap,TreeMap区别

    java为数据结构中的映射定义了一个接口java.util.Map,而HashMap Hashtable和TreeMap就是它的实现类。Map是将键映射到值的对象,一个映射不能包含重复的键;每个键最多只能映射一个一个值。

    Hashmap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度。HashMap最多只允许一条记录的键为Null;允许多条记录的值为 Null;HashMap不支持线程的同步,即任一时刻可以有多个线程同时写HashMap;可能会导致数据的不一致。

    如果需要同步,可以用 Collections的synchronizedMap方法使HashMap具有同步的能力.

    map=Collections.synchronizedMap(hashMap);

    Hashtable 与 HashMap类似,但是主要有6点不同。

    1.HashTable的方法是同步的,HashMap未经同步,所以在多线程场合要手动同步HashMap这个区别就像Vector和ArrayList一样。

    2.HashTable不允许null值,key和value都不可以,HashMap允许null值,key和value都可以。HashMap允许 key值只能由一个null值,因为hashmap如果key值相同,新的key, value将替代旧的。

    3.HashTable有一个contains(Object value)功能和containsValue(Object value)功能一样。

    4.HashTable使用Enumeration,HashMap使用Iterator。

    5.HashTable中hash数组默认大小是11,增加的方式是 old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。

    6.哈希值的使用不同,HashTable直接使用对象的hashCode。

    package com.springTest;
    
    import java.util.HashMap;
    import java.util.Hashtable;
    import java.util.Iterator;
    import java.util.Map;
    import java.util.TreeMap;
    
    public class MapTest {
        public static void main(String[] args) {
            Map<String, String> map = new HashMap<String, String>();
            map.put("a", "aaa");
            map.put("b", "bbb");
            map.put("c", "ccc");
            map.put("d", "ddd");
            Iterator<String> iterator = map.keySet().iterator();
            while (iterator.hasNext()) {
                Object key = iterator.next();
                System.out.println("map.get(" + key + ") is :" + map.get(key));
            }
            System.out.println("-------------------");
    
            Hashtable<String, String> tab = new Hashtable<String, String>();
            tab.put("a", "aaa");
            tab.put("b", "bbb");
            tab.put("c", "ccc");
            tab.put("d", "ddd");
            Iterator<String> iterator_1 = tab.keySet().iterator();
            while (iterator_1.hasNext()) {
                Object key = iterator_1.next();
                System.out.println("tab.get(" + key + ") is :" + tab.get(key));
            }
            System.out.println("-------------------");
    
            TreeMap<String, String> tmp = new TreeMap<String, String>();
            tmp.put("a", "aaa");
            tmp.put("b", "bbb");
            tmp.put("c", "ccc");
            tmp.put("d", "ddd");
            Iterator<String> iterator_2 = tmp.keySet().iterator();
            while (iterator_2.hasNext()) {
                Object key = iterator_2.next();
                System.out.println("tmp.get(" + key + ") is :" + tmp.get(key));
            }
        }
    }
  • 相关阅读:
    负载均衡(负载平衡)
    JavaScript中绑定事件监听函数的通用方法[ addEvent() ]
    有趣的浏览器检测
    IE6 bug之 href= “javascript:void(0);”
    SVN使用技巧 不要把不必要的文件版本化 *.suo,*.bin,*.obj
    CacheDependency缓存依赖里面的 absoluteExpiration(绝对到期时间),弹性到期时间(slidingExpiration)
    TimeSpan 和 DateTime
    字符串数组 string[] 转换为 字符串(用逗号,作为分隔符),linq Except的用法,linq获取两个字符串数组相同的部分
    List的ToLookup 分组方法
    mysql 返回查询结果,返回out返回值,多表联合查询的分页存储过程
  • 原文地址:https://www.cnblogs.com/esther-qing/p/6492155.html
Copyright © 2011-2022 走看看