15.原子变量与非阻塞同步机制CAS

本文深入探讨了锁的劣势,如高开销和阻塞性质,并介绍了硬件级并发支持,如CAS及其在JVM中的应用。通过对比锁与原子变量,讲解了原子变量类和非阻塞算法的优势,包括非阻塞栈、链表和ABA问题解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1锁的劣势

2硬件对并发的支持

2.1CAS

2.2非阻塞的计数器

2.3JVM对CAS的支持

3原子变量类

3.1原子变量是一种“更好的volatile”

3.2性能比较:锁与原子变量

4非阻塞算法

4.1非阻塞的栈

4.2非阻塞的链表LinkedQueue

4.3原子的域更新器(ConcurrentLinkedQueue)

4.4ABA问题

总结


1锁的劣势

①挂起恢复线程开销大,

②如果竞争激烈,调度开销与工作开销比例大

③当一个线程等待锁时,不能做其他事情。如果持锁线程出现问题,那么所有等待该锁的线程都要继续等待。

volatile不会发生上下文切换或线程调度,但不保证原子性

 

2硬件对并发的支持

乐观锁:不断重试

2.1CAS

多线程同时使用CAS更新变量时,失败线程不会挂起与阻塞(不同于锁),

2.2非阻塞的计数器

  • CAS的缺点

2.3JVM对CAS的支持

 

3原子变量类

3.1原子变量是一种“更好的volatile”

3.2性能比较:锁与原子变量

 

4非阻塞算法

4.1非阻塞的栈

4.2非阻塞的链表LinkedQueue

4.3原子的域更新器(ConcurrentLinkedQueue)

4.4ABA问题

 

总结

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值