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

本文探讨Java7中高级同步机制的应用,包括信号量、倒计时门栓、循环障碍及交换所等,旨在帮助读者理解如何在多线程环境中有效控制资源访问和线程间的同步。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[笔记][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来保护临界区,而其他的辅助类则需要根据各自的特性来选择合适的使用场景。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值