多线程(四):线程里锁的概念

本文介绍了悲观锁和乐观锁的概念及区别,以Java为例,重点讲解了乐观锁的CAS算法和其存在的ABA问题。此外,还探讨了原子类AtomicInteger以及线程局部变量ThreadLocal的原理和应用场景。
摘要由CSDN通过智能技术生成

学习内容:

提示:这里可以添加要学的内容
例如:
1、 悲观锁和乐观锁
2、 原子类
3、 ThreadLocal
4、 了解什么是ABA问题


悲观锁和乐观锁

悲观锁

比喻:是一个一朝被蛇咬,十年怕井绳一样,认为谁都要抢我的东西,所以需要挨个问一下你是干嘛的。

就是认为线程的安全问题时常发生,所以会进行上锁,但是上锁有一个问题就是浪费比较多的资源和见底程序的性能,因为里面会有上锁和锁释放的过程

乐观锁

比喻:不会防着所有人,认为周围都是好人
虽然不会防着但是自己也会留个心眼,有两个方案:

  • 版本号机制
    利用版本号记录数据更新的次数,一旦更新版本号加1,线程修改数据后会判断版本号是否是自己更新的次数,如果不是就不更新数据。
  • CAS (Compare And Swap)比较和交换算法
    • 通过内存的偏移量获得数据的值
    • 计算出一个预计的值
    • 将提交的实际值和预计值进行比较,如果相同执行修改,如果不同就不修改

悲观锁和乐观锁对比

  • 悲观锁更加重量级,占用资源更多,应用线程竞争比较频繁的情况,多写少读的场景
  • 乐观锁更加轻量级,性能更高,应用于线程竞争比较少的情况,多读少写的场景

原子类

AtomicInteger类

原子整数,底层使用了CAS算法实现整数递增和递减操作

常用方法:

  • incrementAndGet 原子递增
  • decrementAndGet 原子递减
public class AtomicDemo {
   

    static int count = 0;

    static AtomicInteger integer = new 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值