Java并发分析—ConcurrentHashMap】的更多相关文章

LZ在 https://www.cnblogs.com/xyzyj/p/6696545.html 中简单介绍了List和Map中的常用集合,唯独没有CurrentHashMap.原因是CurrentHashMap太复杂了,于是新开一篇,将在这里将隆重介绍. 在java中,hashMap 和hashTable 与 currentHashMap 的关系比较密切,所以LZ在这多啰嗦一下,从hashMap,hashTable说起,再逐渐过渡到CurrentHashMap,以便于读者更能清晰地理解它的来龙…
java并发初探ConcurrentHashMap Doug Lea在java并发上创造了不可磨灭的功劳,ConcurrentHashMap体现这位大师的非凡能力. 1.8中ConcurrentHashMap的线程安全 1.volatile Node<k,v> []table保证数组的可见性 2.get操作没有加锁 3.put操作调用final V putVal(K key, V value, boolean onlyIfAbsent) ,在方法内部为Syncronized方法加锁,Syncr…
引子 1.不安全:大家都知道HashMap不是线程安全的,在多线程环境下,对HashMap进行put操作会导致死循环.是因为多线程会导致Entry链表形成环形数据结构,这样Entry的next节点将永远不为空,就会产生死循环获取Entry.具体内容见HashMap随笔. 2.不高效:Collections.synchronizedMap(hashMap)和HashTable的线程安全原理都是对方法进行同步,所有操作竞争同一把锁,性能比较低. 如何构造一个线程安全且高效的HashMap?Concu…
在https://www.cnblogs.com/xyzyj/p/11148497.html中已经说明了在多线程并发的情况下,会出现数据的不一致问题,但归根结底就是一个原因,在宏观上就是线程的执行顺序导致的,上文中是通过synchronized解决了线程对共享变量的互斥操作.而在微观上,有个指令重排也会导致数据不一致问题.指令重排是一个比较复杂的概念,这里先从内存模型说起. 1 .内存模型 内存模型是java虚拟机规范的一种用来屏蔽掉各种硬件和操作系统的内存访问差异,以实现让Java程序在各种平…
在计算机操作系统中,并发在宏观上是指在同一时间段内,同时有多道程序在运行. 一个程序可以对应一个进程或多个进程,进程有独立的存储空间.一个进程包含一个或多个线程.线程堆空间是共享的,栈空间是私有的.同样,在一个进程中,宏观上有多个线程同时运行.(微观上在单cup系统中,同一时刻,只有一个程序在运行.) 基于以上原理,线程在并发运行时,对共享数据的操作存在数据同步问题. 1.基本概念 1.什么样的数据会被存储在线程共享空间堆里? 对象,当使用new 关键字创建一个对象时,这个对象就被存储在堆里.…
目录 重要属性和类 put 为什么java8后放弃分段锁,改用CAS和同步锁 初始化 addCount 扩容 树化 参考 重要属性和类 sizeCtl 容量控制标识符,在不同的地方有不同用途,而且它的取值不同,也代表不同的含义. 负数代表正在进行初始化或扩容操作,-1代表正在初始化 -N 表示有N-1个线程正在进行扩容操作 正数或0代表hash冲突链表还没有被初始化,这个数值表示初始化或下一次进行扩容的大小,这一点类似于扩容阈值的概念.后面可以看到,它的值始终是当前ConcurrentHashM…
特点: 将桶分段,并在某个段上加锁,提高并发能力 源码分析: V put(K key, int hash, V value, boolean onlyIfAbsent) { lock(); try { int c = count; if (c++ > threshold) // ensure capacity rehash(); HashEntry<K,V>[] tab = table; int index = hash & (tab.length - 1); HashEntry…
转载 http://www.importnew.com/26035.html 最近在做接口限流时涉及到了一个有意思问题,牵扯出了关于concurrentHashMap的一些用法,以及CAS的一些概念.限流算法很多,我主要就以最简单的计数器法来做引.先抽象化一下需求:统计每个接口访问的次数.一个接口对应一个url,也就是一个字符串,每调用一次对其进行加一处理.可能出现的问题主要有三个: 多线程访问,需要选择合适的并发容器 分布式下多个实例统计接口流量需要共享内存 流量统计应该尽可能不损耗服务器性能…
1.Lock 和 Condition 当使用synchronied进行同步时,可以在同步代码块中只用常用的wait和notify等方法,在使用显示锁的时候,将通过Condition对象与任意Lock实现组合使用,为每个对象提供多个等待方法,其中Lock代替了synchronized方法和语句的使用,Condition代替了Object监视器方法的使用,条件Condition为线程提供了一个含义,以便在某个状态条出现可能为true,另一个线程通知它之前,一直挂起该线程,即让其等待,因为访问该共享状…
1. ConcurrentHashMap 2. ConcurrentLinkedQueue 3. ConcurrentSkipListMap 4. ConcurrentSkipListSet 5. txt java 并发容器 ConcurrentHashMap 并发编程中需要用到线程安全的HashMap 为什么要用 1. 线程不安全的HashMap 数据丢失:put的时候导致的多线程数据不一致 比如有两个线程A和B,首先A希望插入一个key-value对到HashMap中,首先计算记录所要落到的…