并发编程
-
CountDownLatch的使用与原理
CountDownLatch是一个线程同步工具类,它允许一个线程或多个线程一直处于等待状态,直到其他线程执行结束。它是一个倒数的计时器,提供了两个核心的方法。 countDown(…
-
java 同步锁:synchronized 关键字简单分析
简介 synchronized关键字是Java里面最基本的同步手段,它经过编译之后,会在同步块的前后分别生成 monitorenter和 monitorexit…
-
源码分析:同步基础框架之 AbstractQueuedSynchronizer(AQS)
简介 AQS 全称是 AbstractQueuedSynchronizer,位于java.util.concurrent.locks 包下面,AQS 提供了一个…
-
源码分析:①ReentrantLock之公平锁和非公平锁
简介 ReentrantLock 是JDK 1.5开始提供的一种可重入的互斥锁,并且构造方法支持公平性参数。 源码分析 类结构体系 ReentrantLock实现了Lock接口: …
-
源码分析:②ReentrantLock之条件锁Condition
简介 条件锁,指在获得锁之后,还需要达成某些条件后,才能继续执行的锁。且必须配合Lock一起使用,也就是说必须获得锁之后才可以调用condition.await()方法 源码分析 …
-
源码分析:ReentrantReadWriteLock之读写锁
简介 ReentrantReadWriteLock 从字面意思可以看出,是和重入、读写有关系的锁,实际上 ReentrantReadWriteLock 确实也是支持可重入的读写锁,…
-
源码分析:Semaphore之信号量
简介 Semaphore 又名计数信号量,从概念上来讲,信号量初始并维护一定数量的许可证,使用之前先要先获得一个许可,用完之后再释放一个许可。信号量通常用于限制线程的数量来控制访问…
-
源码分析:CountDownLatch 之倒计时门栓
简介 CountDownLatch 是JDK1.5 开始提供的一种同步辅助工具,它允许一个或多个线程一直等待,直到其他线程执行的操作完成为止。在初始化的时候给定 CountDown…
-
源码分析:CyclicBarrier 之循环栅栏
简介 CyclicBarrier 是一个同步辅助工具,允许一组线程全部等待彼此达到共同屏障点,且等待的线程被释放后还可以重新使用,所以叫做Cyclic(循环的)。 应用场景 比如出…
-
源码分析:Exchanger之数据交换器
简介 Exchanger是Java5 开始引入的一个类,它允许两个线程之间交换持有的数据。当Exchanger在一个线程中调用exchange方法之后,会阻塞等待另一个线程调用同样…
-
源码分析:Phaser 之更灵活的同步屏障
简介 Phaser 是 JDK 1.7 开始提供的一个可重复使用的同步屏障,功能类似于CyclicBarrier和CountDownLatch,但使用更灵活,支持对任务的…
-
1.Java JUC 简介
在 Java 5.0 提供了 java.util.concurrent (简称JUC )包,在此包中增加了在并发编程中很常用的实用工具类,用于定义类似于线程的自定义子系统,包括线程…
-
2.volatile 关键字-内存可见性
2.volatile 关键字-内存可见性 前言 在多线程并发中,常常存在多个线程同时操作一个共享属性的情况。而这种情况通常会带来一个 内存可见性 的问题。那么本篇章来介绍一下这个问…
-
3.原子变量 CAS算法
3.原子变量 CAS算法 前言 在上一篇中我们讲述了关于多线程并发,导致共享属性在内存不可见的问题。以及使用 volatile 关键字设置共享属性,使其在多线程并发中内存可见。 但…
-
4.ConcurrentHashMap 锁分段机制
4.ConcurrentHashMap 锁分段机制 ConcurrentHashMap – Java 5.0 在 java.util.concurrent 包中…
-
5.CountDownLatch 闭锁
5.CountDownLatch 闭锁 需求 在多线程开发中,我们总会有一些需求处理,需要在多个线程全部执行完毕后,最后执行的。例如:统计所有线程的运行时长。 一般直接使用多线程是…