ConcurrentHashMap 的例子

Posted

技术标签:

【中文标题】ConcurrentHashMap 的例子【英文标题】:examples of ConcurrentHashMap 【发布时间】:2011-05-04 01:41:51 【问题描述】:

我正在阅读文章“Java theory and practice: Building a better HashMap”,它很好地概述了 ConcurrentHashMap 的实现。

我还在 *** here 上找到了一些关于它的讨论。

我的疑问是“使用 ConcurrentHashMap 的场景/应用程序/地点是什么”。

谢谢

【问题讨论】:

【参考方案1】:

您将在使用HashMap 的相同实例中使用ConcurrentHashMap,但您计划使用映射的线程不止一个。

【讨论】:

【参考方案2】:

例如,我用它来快速查找从用户 ID 到多线程服务器中的用户对象。

我有一个网络线程、一个用于定期任务的计时器线程和一个用于处理控制台输入的线程。多线程访问用户的hash map,需要线程安全。

【讨论】:

【参考方案3】:

对于大型 Map 或大量读写操作,建议使用 ConcurrentHashMap,原因如下:

从地图读取时,它没有被锁定。因此,如果有 5 个线程正在从中读取,则它们都可以同时从 map 中读取。 在写入时,只有相关记录(键)被锁定。因此,如果 5 个线程正在写入不同键的值,则所有这些操作可以同时发生。但是,如果 2 个线程正在写入同一个键,则这些操作是线程安全的。发生这种情况是因为在对象(映射)级别没有锁定,而是在更精细的粒度 - 在哈希映射存储桶级别。

考虑以下示例:

public class ConcurrentHashMapExample 

    public static void main(String[] args) 

        //ConcurrentHashMap
        Map<String,String> myMap = new ConcurrentHashMap<String,String>();
        myMap.put("1", "1");
        myMap.put("2", "1");
        myMap.put("3", "1");
        myMap.put("4", "1");
        myMap.put("5", "1");
        myMap.put("6", "1");
        System.out.println("ConcurrentHashMap before iterator: "+myMap);
        Iterator<String> itr1 = myMap.keySet().iterator();

        while(itr1.hasNext())
            String key = itr1.next();
            if(key.equals("3")) myMap.put(key+"new", "new3");
        
        System.out.println("ConcurrentHashMap after iterator: "+myMap);

        //HashMap
        myMap = new HashMap<String,String>();
        myMap.put("1", "1");
        myMap.put("2", "1");
        myMap.put("3", "1");
        myMap.put("4", "1");
        myMap.put("5", "1");
        myMap.put("6", "1");
        System.out.println("HashMap before iterator: "+myMap);
        Iterator<String> itr2 = myMap.keySet().iterator();

        while(itr2.hasNext())
            String key = itr2.next();
            if(key.equals("3")) myMap.put(key+"new", "new3");
        
        System.out.println("HashMap after iterator: "+myMap);
    

输出将是:

ConcurrentHashMap before iterator: 1=1, 5=1, 6=1, 3=1, 4=1, 2=1
ConcurrentHashMap after iterator: 1=1, 3new=new3, 5=1, 6=1, 3=1, 4=1, 2=1
HashMap before iterator: 3=1, 2=1, 1=1, 6=1, 5=1, 4=1
Exception in thread "main" java.util.ConcurrentModificationException
    at java.util.HashMap$HashIterator.nextEntry(HashMap.java:793)
    at java.util.HashMap$KeyIterator.next(HashMap.java:828)
    at com.test.ConcurrentHashMapExample.main(ConcurrentHashMapExample.java:44)

如您所见,对于HashMapConcurrentModificationException 将被抛出,因为您尝试更改当前迭代的地图! (具体会在语句上抛出异常:String key = itr1.next();

【讨论】:

以上是关于ConcurrentHashMap 的例子的主要内容,如果未能解决你的问题,请参考以下文章

concurrenthasmap

ConcurrentHashMap小例子应用

SQL Server 中 Conc() 的等价物是啥

Collections.synchronizedMap()与ConcurrentHashMap的区别

php Añadirmenúconc短代码

EBS 并发请求 计划 fnd_conc_release_classes