Java之通过Collections.synchronizedMap创建线程安全的HashMap

1 问题

我们知道hashMap线程是不安全的,一般而言,我们怎么创建线程安全的HashMap呢?

 
2 解决办法

我们可以使用Collections.synchronizedMap来创建HashMap,如下

static Map<String, String> results = Collections.synchronizedMap(new HashMap<String, String>());

 
3 Collections.synchronizedMap源码部分实现

我们先看synchronizedMap如果创建

    public static <K,V> Map<K,V> synchronizedMap(Map<K,V> m) {
        return new SynchronizedMap<K,V>(m);
    }

我们看下具体的SynchronizedMap类的部分

    private static class SynchronizedMap<K,V>
        implements Map<K,V>, Serializable {
        // use serialVersionUID from JDK 1.2.2 for interoperability
        private static final long serialVersionUID = 1978198479659022715L;
     
        private final Map<K,V> m;     // Backing Map
            final Object      mutex;    // Object on which to synchronize
     
        SynchronizedMap(Map<K,V> m) {
                if (m==null)
                    throw new NullPointerException();
                this.m = m;
                mutex = this;
            }
     
        SynchronizedMap(Map<K,V> m, Object mutex) {
                this.m = m;
                this.mutex = mutex;
            }
     
        public int size() {
            synchronized(mutex) {return m.size();}
            }
        public boolean isEmpty(){
            synchronized(mutex) {return m.isEmpty();}
            }
        public boolean containsKey(Object key) {
            synchronized(mutex) {return m.containsKey(key);}
            }
        public boolean containsValue(Object value){
            synchronized(mutex) {return m.containsValue(value);}
            }
        public V get(Object key) {
            synchronized(mutex) {return m.get(key);}
            }
     
        public V put(K key, V value) {
            synchronized(mutex) {return m.put(key, value);}
            }
        public V remove(Object key) {
            synchronized(mutex) {return m.remove(key);}
            }
        public void putAll(Map<? extends K, ? extends V> map) {
            synchronized(mutex) {m.putAll(map);}
            }
        public void clear() {
            synchronized(mutex) {m.clear();}
        }
     
        private transient Set<K> keySet = null;
        private transient Set<Map.Entry<K,V>> entrySet = null;
        private transient Collection<V> values = null;
     
        public Set<K> keySet() {
                synchronized(mutex) {
                    if (keySet==null)
                        keySet = new SynchronizedSet<K>(m.keySet(), mutex);
                    return keySet;

更多请见:http://www.mark-to-win.com/tutorial/51775.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值