java多线程-悲观锁、乐观锁

本文探讨了悲观锁的同步机制,如`synchronized`,导致性能下降,然后介绍了乐观锁的乐观态度,如Java中的AtomicInteger和CAS算法,强调在并发场景下线程安全与性能优化的重要性。
摘要由CSDN通过智能技术生成

简介

  • 悲观锁:没有安全感,一上来就直接加锁,每次只能一个线程进入访问,访问完毕之后,再解锁。线程安全,但是性能差。
  • 乐观锁:很乐观,一开始不上锁,认为没有问题。等到要出现线程安全问题的时候才进行控制,线程安全,性能好。

同步-悲观锁

之前学习的同步思想就是 悲观锁

public class MyRunnable implements Runnable{

    private int count = 0;

    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            add();
        }
    }


    public synchronized   void add(){
        System.out.println("count = " +   (++count));
    }

}
Runnable runnable = new MyRunnable();
  for (int i = 1; i <= 100; i++) {
      new Thread(runnable).start();
  }

乐观锁

  • 首先我们可以假设一下,其实出现线程安全问题的概率并不大
  • 遵循的事CAS算法:compare and set
  • 每次执行修改代码之前,记录原始的数值,当修改的时候,比较一下是不是还是原始值
    • 如果是原始值,线程安全,修改值
    • 如果不是原始值,现成不按照,废除此次执行,使用修改后的值再重新执行
  • 因为乐观锁是一个非常重要的概念,所以java中已经内置了很多乐观锁机制
public class MyRunnable implements Runnable{

    // private int count = 0;
    // 整数修改的乐观锁:原子类进行实现
    private AtomicInteger count = new AtomicInteger(0);

    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            add();
        }
    }


    public    void add(){
        // 对数值先加1,再输出
        System.out.println("count = " +   count.incrementAndGet());
    }

}

在这里插入图片描述

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值