Java7并发编程--3、线程同步辅助类

       常用的同步有synchronized关键字、Lock接口以及实现类,如ReentrantLock、ReentrantReadWriteLock中的ReadLock和WriteLock。

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值