3.ConcurrentHashMap 锁分段机制 Copy-On-Write
/*ConcurrentHashMap*/
Java 5.0 在 java.util.concurrent 包中提供了 多种 并发容器来改进同步容器的性能
ConcurrentHashMap 同步容器类 是 Java5 增加的一个线程安全的 哈希表。对于多线程的操作,介于HashMap 与 HashTable 之间
HashMap 是线程不安全的,不支持并发操作
HashTable 是线程安全的,采用的独占锁,即一次只能有一个线程对容器进行操作
HashTable 还有一个问题,当执行一些复合操作,如:若存在,则删除, if(!table.contans()) { table.put() } ,同样可能出现线程问题
ConcurrentHashMap 介于 HashMap 与 Hashtable 之间。内部采用 “锁分段”机制替代Hashtable的独占锁。进而提高性能(在jdk1.8之后,底层就不采用锁分段的方式了,而是采用CAS算法)
锁分段:
有一个concurrentLevel(分段级别)(默认的级别为16),将锁分成16段,每个段都是一个独立的锁,每段锁会有16(默认)个Entry
当有多个线程并发访问时,可以访问不同的段,实现了并行, 提高了效率,并且提供了一些复合操作的方法
/*其他并发容器类*/
JUC 还提供了其他用于多线程上下文中Collection 实现(以前只能 用synchronize 来同步这些集合的方法,实现同步):
ConcurrentHashMap、ConcurrentSkipListMap、ConcurrentSkipListSet、CopyOnWriteArrayList 和 CopyOnWriteArraySet
1.当期望许多线程访问一个 给定collection 时,ConcurrentHashMap通常优于同步的HashMap
2.ConcurrentSkipListMap 通常优于同步的TreeMap。
3.当期望的读数 和 遍历 远远大于列表的更新数时,CopyOnWriteArrayList优于同步的ArrayList,
但是 CopyOnWriteArrayList 因为每次更新都会进行复制,开销非常大,并发迭代操作多时可以选择
/*
* CopyOnWriteArrayList /CopyOnWriteArraySet : "写入并复制"
* Copy-On-Write简称COW,是一种用于程序设计中的优化策略。其基本思路是,
*
* 从一开始大家都在共享同一个内容,当某个人想要修改这个内容的时候,才会真正把内容Copy出去形成一个新的内容然后再改,这是一种延时懒惰策略。
*
* 当出现并发,多个线程想对这个内容进行操作,读操作的时候,无所谓,读的都是同一份,也不会加锁;;
* 写操作的时候,为了避免修改同一份,采用的策略是,把内容Copy出去形成一个新的内容然后再改,以此来避免并发问题
*
* 从JDK1.5开始Java并发包里提供了两个使用CopyOnWrite机制实现的并发容器,它们是CopyOnWriteArrayList和CopyOnWriteArraySet。
* CopyOnWrite容器非常有用,可以在非常多的并发场景中使用到
*
* 注意 :添加操作多时,效率低因为每次添加时都会将当前List复制一份,开销非常的大。并发迭代操作时可以选择
* */
public class TestCopyOnWriteArrayList {
public static void main(String[] args) {
ListThread lt = new ListThread();
for(int i = 0;i<10;i++) {
new Thread(lt).start();
}
}
} class ListThread implements Runnable {
//private static List<String> list = Collections.synchronizedList(new ArrayList<String>()); 使用 这种同步的ArrayList,当遍历的时候进行 add 操作,就会报错
private static CopyOnWriteArrayList<String> list = new CopyOnWriteArrayList<String>();
static {
list.add("1");
list.add("2");
list.add("3");
}
@Override
public void run() {
Iterator<String> iterator = list.iterator();
while(iterator.hasNext()) {
System.out.println(iterator.next());
list.add("4");
}
} }
3.ConcurrentHashMap 锁分段机制 Copy-On-Write的更多相关文章
- java多线程 -- ConcurrentHashMap 锁分段 机制
hashtable效率低ConcurrentHashMap 线程安全,效率高 Java 5.0 在 java.util.concurrent 包中提供了多种并发容器类来改进同步容器 的性能. Conc ...
- 四、ConcurrentHashMap 锁分段机制
回顾: HashMap与Hashtable的底层都是哈希表,但是 HashMap:线程不安全 Hashtable:线程安全,但是效率非常低,且存在[复合操作](如"若存在则删除") ...
- 3、JUC--ConcurrentHashMap 锁分段机制
ConcurrentHashMap Java 5.0 在 java.util.concurrent 包中提供了多种并发容器类来改进同步容器的性能. ConcurrentHashMap 同步容器 ...
- ConcurrentHashMap(锁分段技术)
线程不安全的HashMap 因为多线程环境下,使用Hashmap进行put操作会引起死循环,导致CPU利用率接近100%,所以在并发情况下不能使用HashMap. 效率低下的HashTab ...
- Java:ConcurrentHashMap的锁分段技术
术语定义 术语 英文 解释 哈希算法 hash algorithm 是一种将任意内容的输入转换成相同长度输出的加密方式,其输出被称为哈希值. 哈希表 hash table 根据设定的哈希函数H(ke ...
- Java进阶知识点6:并发容器背后的设计理念 - 锁分段、写时复制和弱一致性
一.背景 容器是Java编程中使用频率很高的组件,但Java默认提供的基本容器(ArrayList,HashMap等)均不是线程安全的.当容器和多线程并发编程相遇时,程序员又该何去何从呢? 通常有两种 ...
- 操作系统篇-分段机制与GDT|LDT
|| 版权声明:本文为博主原创文章,未经博主允许不得转载. 一.前言 在<操作系统篇-浅谈实模式与保护模式>中提到了两种模式,我们说在操作系统中,其实大部分时间是待在保护模式中的. ...
- 【JAVA并发编程实战】9、锁分段
package cn.study.concurrency.ch11; /** * 锁分段 * @author xiaof * */ public class StripedMap { //同步策略:就 ...
- Oracle锁的机制
一.为什么要有锁的机制 我们都知道数据库是一个多用户使用的共享资源.当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况.若对并发操作不加控制就可能会读取和存储不正确的数据,破 ...
随机推荐
- win7电脑删除保存的凭据
win7电脑删除保存的凭据: 控制面板-> 用户账户 -> 管理您的凭据
- navigationBarTitleText
想修改整个程序的导航栏,在app.json 文件 修改 "window": { "backgroundTextStyle": "light" ...
- droid AVD创建及设置中各参数详解
设置AVD时有些参数比较模糊,特地找了篇文章,大家参考下! 本文根据如下的模拟器安装做一些解释: Name: 自定义虚拟的名称,不能有空格或者其他非法字符,否则不能创建,即Creat AVD不能高亮点 ...
- react Link标签 火狐失效怎么解决
这个问题其实找了好多资料都没有具体的解决方法: 今天突然想到可能是层级嵌套出问题了,刚好有个bug也是关于这个的,已经亲测解决了 代码如下:火狐和谷歌都能正常的跳转 <Link to=" ...
- Python扫描器-HTTP协议
1.HTTP协议 1.1.HTTP协议简介 #1.HTTP协议,全称Hyper Text Transfer Protocol(超文本传输协议) HTTP协议是用于从(WWW:World Wide We ...
- linux下无法启动webdriver问题
linux下无法启动webdriver问题: 查看是否有足够多的webdriver进程: ps -ef | grep chromedriver kill -9 `ps -ef |grepchromed ...
- mybatis传入map任意表增删改查,分页过滤字段
<!--根据实体参数查询 --> <select id="selectBaseList" resultType="java.util.HashMap&q ...
- SSRF——漏洞利用(二)
0x01 概述 上篇讲述了SSRF的一般用法,用http协议来进行内网探测,攻击内网redis,接下来讨论的是SSRF的拓展用法,通过,file,gopher,dict协议对SSRF漏洞进行利用. 0 ...
- ELK优化难题解决
你头疼的ELK难题,本文几乎都解决了 一.ELK实用知识点总结 1.编码转换问题 这个问题,主要就是中文乱码. input中的codec=>plain转码: codec => plain ...
- uwp,c#,全屏播放保持屏幕响应
在开发视频app的时候,全屏播放一段时间内没有电脑操作,电脑会自动进入睡眠模式,这时就要多写些代码来保持响应了. (这里使用的是MediaElement播放控件,MediaElement需要手动添加代 ...