[笔记][Java7并发编程实战手册]第三章-线程同步辅助类-3.1概要

[笔记][Java7并发编程实战手册]系列目录


有点着急了,没有太注重质量,自己也没有理解透,从本章起,读书和随笔笔记的质量会更好。


第三章

在本章中,我们将学习:

1. 资源的并发访问控制
2. 资源的多副本的并发访问控制
3. 等待多个并发事件的完成
4. 在集合点的同步
5. 并发阶段任务的运行
6. 并发阶段任务中的阶段切换
7. 并发任务间的数据交换


回顾

在第二章中主要学习了以下接口

  1. synchronized关键字
  2. Lock接口以及实现类,如ReentrantLock、ReentrantReadWriteLock中的ReadLock和WriteLock

需要掌握的知识应该有:synchronized关键字的使用,lock接口的使用,在lock锁中使用条件,会使用读写锁,会修改锁的公平性


本章主要围绕以下几点来学习

在本章中将以以下几个更高级的同步机制来实现多线程的同步。

  1. 信号量(Semaphore):
    是一种计数器,用来保护一个或则多个共享资源的访问,它是并发编程的一种基础工具,大多数编程语言都提供了这个机制
    简要场景用途:允许同时n个线程访问某一个资源
  2. 倒计时(CountDownLatch):
    一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。
    简要场景用途: 有一个或则n个线程需要 依赖 某一个或则n个线程执行的结果,拿到结果后,再进行计算
  3. 循环Barrier(CyclicBarrier):
    一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的 barrier。
    简要场景用途: 有一段代码需要等待一个或则n个线程到达一个指定点再执行,或则 有一个线程需要等待一个或则n个线程到底某一个点,这个线程才能被执行。
  4. Phaser:JAVA1.7新特性
    一个同步辅助类,类似CyclicBarrier的关卡屏障,但是比它更加灵活,它把并发任务分成多个阶段运行,在开始下一个阶段之前,当前阶段中的所有线程都必须执行完成。
    简要场景用途:这个更强大,除了能实现2,3的功能外,没法一句话描述清楚
  5. 交换所(Exchanger)
    一个同步辅助类,提供了两个线程之前的数据交换点。
    简要场景用途:用于两个线程消费者和生产者之间的数据交换。

在应用程序中,任何时候都可以使用Semaphore来保护临界区,而其他的辅助类则需要根据各自的特性来选择合适的使用场景。

你可能感兴趣的:(Java7并发编程)