【Java进阶营】synchronized同步锁的使用与原理

本文探讨了在多线程环境下,无锁代码可能导致的问题,例如并发计数不准确。解决方案是使用`synchronized`关键字,它提供了内置的原子性和线程同步。详细介绍了`synchronized`的三种使用方式,并深入讲解了它的原理,包括Mark Word、锁升级过程,从无锁到偏向锁、轻量级锁再到重量级锁的变化。通过理解`synchronized`的工作机制,开发者可以更好地理解和使用这把同步锁。
摘要由CSDN通过智能技术生成

多线程下,无锁代码可能产生的问题

首先看下面的代码,逻辑很简单,定义了5个线程,这5个线程分别对同一个对象的成员变量num进行10000次递增操作,最后等待所有线程执行完成后,将num结果输出。

image.png

正常情况下,我们预期的输出是50000,但运行程序之后,实际输出结果并不是如此,结果可能是50000,也可能小于50000。

image.png

为什么会出现结果小于50000的情况呢?

首先,我们要知道,线程在执行"num++"这句代码时,实际上会执行三个动作:

读取num的值;

修改num的值;

将修改后的num刷新到内存中。

由于此处有5个线程同时在执行这段代码,所以可能出现这种情况:线程1读取到了num的值为0,此时,线程1还没有执行修改num值的动作,线程2也读取了num的值,那么线程2读取到的num的值也是0,那此时线程1和线程2对num做递增操作时,都是对0进行加1,所以线程1和线程2的运行结果都是1。可以看到,虽然线程1和线程2都对num执行了一次++操作,但结果并不是2,而是1。

这就是导

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值