首页 > 代码库 > 《Java并发编程实战》第五章 同步容器类 读书笔记
《Java并发编程实战》第五章 同步容器类 读书笔记
一、同步容器类
1. 同步容器类的问题线程容器类都是线程安全的,但是当在其上进行符合操作则需要而外加锁保护其安全性。
常见符合操作包含:
. 迭代
. 跳转(根据指定顺序找到当前元素的下一个元素)
. 条件运算
迭代问题可以查看之前的文章
《Java ConcurrentModificationException 异常分析与解决方案》
二、并发容器
集合类型 | 非线程安全 | 线程安全 |
List | ArrayList | CopyOnWriteArrayList |
Set | SortedSet | ConcurrentSkipListSet |
Map | HashMap、SortedMap | ConcurrentHashMap、ConcurrentSkipListMap、 |
ConcurrentHashMap
CopyOnWriteArrayList
三、阻塞队列 - 生产者消费者模式
队列 - BlockingQueue
四、阻塞方法与中断方法
以下内容摘录自《温绍锦 - Java并发程序设计教程-》
// 第一种方式 Thread thread = new Thread("interrupt test") { public void run() { for (;;) { doXXX(); if (Thread.interrupted()) { break; } } } }; thread.start(); // 第二种方式 Thread thread = new Thread("interrupt test") { public void run() { for (;;) { try { doXXX(); } catch (InterruptedException e) { break; } catch (Exception e) { // handle Exception } } } }; thread.start(); // 第三种方式 public void foo() throws InterruptedException { if (Thread.interrupted()) { throw new InterruptedException(); } }
程序应该对线程中断作出恰当的响应。
五、同步工具类
1. 闭锁 CountDownLatch
2. FutureTask
3. 信号量
4. 栅栏(Barrier)
六、构建高效且可伸缩的结果缓存
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。