从零开始java多线程并发---锁(三):AQS的实现方法说明

一:AQS解释了锁的核心思路

  实则是,java中的锁就是我们定义了访问公共资源的一种方法。AQS是创建多线程下资源管理的核心,其通过以FIFO队列的方式定义了线程对于公共资源的操作

 

二:模板功能的复写

   AQS的实现类实则就是腹泻了AQS的抽象功能(但是AQS中多数使用final、static修饰的变量和方法声明其为一个模板),下面对于其抽象方法的复写如下:

                   

 

三:线程响应中断、超时支持更灵活的线程调度 

          线程中断:实则多核CPU在处理多指令集的命令时,是以同时快速切换线程运行核来实现多核运行的,也就是说一个线程                                可能在切换时导致线程处理中断。

          响应中断:是指线程在中断时能够及时的返回而不会产生“死锁”(一般死锁是指线程超时而未响应中断)。也就是说,响                                  应中断提供了多线程在并发情况下的一个更加灵活的线程操作。

 

四:CAS操作

   上节提到CAS操作保证了锁的可靠性,这里我们就来谈一下什么事CAS操作。CAS操作定义命令是:判断是否与预期值一致,一致的话修改,不一致返回。(具体事例:比如我们在进行“审核”操作时,都需要先判断改数据是否有被其他人审核过)。java中关于CAS操作都是交由Unsafe(并发包下的元子类框架中)。

 

五:FIFO等待队列的操作

  在上一节谈到FiFO是AQS维护的一个中哟核心东西(另一个是“共享资源”)

                  

六:共享资源的获取操作 (获取锁)

七:释放资源(释放锁) 

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值