《Java并发编程实战》第五章 同步容器类 读书笔记


一、同步容器类

1. 同步容器类的问题
线程容器类都是线程安全的,但是当在其上进行符合操作则需要而外加锁保护其安全性。

常见符合操作包含:
. 迭代
. 跳转(根据指定顺序找到当前元素的下一个元素)
. 条件运算

迭代问题可以查看之前的文章


二、并发容器


集合类型 非线程安全 线程安全
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)

六、构建高效且可伸缩的结果缓存



《Java并发编程实战》第五章 同步容器类 读书笔记,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。