JUC总结-基础篇

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标记找到一条完整的链表数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值