标签: 同步
All the articles with the tag "同步".
源码分析:Phaser 之更灵活的同步屏障
Published: at 18:07:27JDK源码分析 Phaser,Phaser 是 JDK 1.7 开始提供的一个可重复使用的同步屏障,功能类似于 CyclicBarrier 和 CountDownLatch,但使用更灵活,支持对任务的动态调整,并支持分层结构来达到更高的吞吐量。
源码分析:Exchanger之数据交换器
Published: at 21:46:42JDK源码分析Exchanger,Exchanger是Java5 开始引入的一个类,它允许两个线程之间交换持有的数据。
源码分析:CyclicBarrier 之循环栅栏
Published: at 13:45:47JDK源码分析 CyclicBarrier,CyclicBarrier 是一个同步辅助工具,允许一组线程全部等待彼此达到共同屏障点,且等待的线程被释放后还可以重新使用,所以叫做Cyclic(循环的)。
AbstractQueuedSynchronizer(AQS) 总结篇
Published: at 11:38:25AQS 全称是AbstractQueuedSynchronizer,在java.util.concurrent.locks包下面,是一个抽象的可以实现阻塞线程、排队控制、唤醒线程等操作的同步器基础框架类,AQS 可以实现排它锁、共享锁、条件锁、计数器等相关功能。
源码分析:CountDownLatch 之倒计时门栓
Published: at 19:25:51JDK源码分析 CountDownLatch,CountDownLatch 是JDK1.5 开始提供的一种同步辅助工具,它允许一个或多个线程一直等待,直到其他线程执行的操作完成为止。在初始化的时候给定 CountDownLatch 一个计数,调用await() 方法的线程会一直等待,其他线程执行完操作后调用countDown(),当计数减到0 ,调用await() 方法的线程被唤醒继续执行。
源码分析:Semaphore之信号量
Published: at 16:01:07JDK源码分析 Semaphore,Semaphore 又名计数信号量,从概念上来讲,信号量初始并维护一定数量的许可证,使用之前先要先获得一个许可,用完之后再释放一个许可。信号量通常用于限制线程的数量来控制访问某些资源,从而达到单机限流的目的,比如SpringCloud 中的Zuul 组件用的是 Hystrix 的信号量(semaphore)隔离模式。
源码分析:StampedLock之升级版的读写锁
Published: at 18:05:59JDK StampedLock 源码分析,StampedLock 是JDK1.8 开始提供的一种锁, 是对之前介绍的读写锁 ReentrantReadWriteLock 的功能增强。StampedLock 有三种模式:Writing(写)、Reading(读)、Optimistic Reading(乐观度),StampedLock 的功能不是基于AQS来实现的,而是完全自己内部实现的功能,不支持重入。在加锁的时候会返回一个戳,解锁的时候需要传入,匹配完成解锁操作。