juc是什么?
JUC是java.util.concurrent包的简称,在Java5.0添加,目的就是为了更好的支持高并发任务。让开发者进行多线程编程时减少竞争条件和死锁的问题!
juc脑图
juc总结
juc多数工具都是依赖volatile关键字保持可见性和禁止指令重排,通过unsafe保持原子性。例如:aqs
可以找几个具体的去工具包看看。很是清爽
juc番外篇
CountDownLatch和Semaphore的区别和底层原理
区别
CountDownLatch:
CountDownLatch表示计数器,可以给CountDownLatch设置⼀个数字,⼀个线程调用CountDownLatch的await()将会阻塞,其他线程可以调⽤CountDownLatch的countDown()⽅法来对CountDownLatch中的数字减⼀,当数字被减成0后,所有await的线程都将被唤醒。
Semaphore:
Semaphore表示信号量,可以设置许可的个数,表示同时允许最多多少个线程使⽤该信号量,通过 acquire() 来获取许可,如果没有许可可⽤则线程阻塞,并通过AQS来排队,可以通过 release()⽅法来释放许可,当某个线程释放了某个许可后,会从AQS中正在排队的第⼀个线程开始依次唤醒,直到没有空闲许可。
原理
他们俩都是通过AQS排队
AbstractQueuedSynchronizer
AQS 的底层数据结构其实是一条双向链表、一个代表锁状态的变量 state
和一个Condition
。当加锁后,state会改变,而竞争锁的线程会被封装到节点中形成链表,并且尝试改变 state以获取锁。
通俗点:AQS 本身只记录了共享变量,和双向链表的首尾Node等,但是最终可以通过Node标记找到一条完整的链表数据