一:AQS解释了锁的核心思路
实则是,java中的锁就是我们定义了访问公共资源的一种方法。AQS是创建多线程下资源管理的核心,其通过以FIFO队列的方式定义了线程对于公共资源的操作。
二:模板功能的复写
AQS的实现类实则就是腹泻了AQS的抽象功能(但是AQS中多数使用final、static修饰的变量和方法声明其为一个模板),下面对于其抽象方法的复写如下:
三:线程响应中断、超时支持更灵活的线程调度
线程中断:实则多核CPU在处理多指令集的命令时,是以同时快速切换线程运行核来实现多核运行的,也就是说一个线程 可能在切换时导致线程处理中断。
响应中断:是指线程在中断时能够及时的返回而不会产生“死锁”(一般死锁是指线程超时而未响应中断)。也就是说,响 应中断提供了多线程在并发情况下的一个更加灵活的线程操作。
四:CAS操作
上节提到CAS操作保证了锁的可靠性,这里我们就来谈一下什么事CAS操作。CAS操作定义命令是:判断是否与预期值一致,一致的话修改,不一致返回。(具体事例:比如我们在进行“审核”操作时,都需要先判断改数据是否有被其他人审核过)。java中关于CAS操作都是交由Unsafe(并发包下的元子类框架中)。
五:FIFO等待队列的操作
在上一节谈到FiFO是AQS维护的一个中哟核心东西(另一个是“共享资源”)
六:共享资源的获取操作 (获取锁)
七:释放资源(释放锁)