2016 - 2024

感恩一路有你

java给方法加锁 java线程锁为什么锁不住?

浏览量:2755 时间:2021-03-18 20:14:10 作者:admin

java线程锁为什么锁不住?

主要问题没有给出完整的代码和运行结果,我分析这个代码没有问题,可以正确运行。

在这段代码中,使用了savemoney类对象的锁。这个对象在运行时只有一个实例,这确保了在代码执行时只有一个线程可以获得锁。其他线程必须等待锁保持线程释放锁,然后才能进入。因此,主体需要补充如何在无法锁定的情况下得出结论。

我还原了代码并给出了如下运行结果:

运行的代码应该与所有者的代码一致

运行结果表明三个线程互斥执行同步代码块。

欢迎批评指正。如果你认为业主的回答是好的,请表扬并注意^V^

首先,你需要知道在非分布式环境下用锁可以解决什么问题?

多线程环境,共享资源线程安全问题!此时,共享资源通常在一台机器的多线程中竞争。从JAVA内存模型的角度来看,我们可以通过锁定对象、方法和代码块来避免共享资源的竞争

!1,生成全局ID;

2,修改全局配置文件;

3,分布式服务中的seckill;

4,分布式环境中的重复提交;

1,使用数据库的唯一主键实现锁定

!2、使用redis指令:通常使用setnx方法,incr方法实现

3、使用zookeeper:使用API生成临时节点实现锁定

什么时候需要分布式锁?

谢谢

!Java语言规范明确指出,如果锁定的对象为null,则会发生NullPointerException。规范的内容如下:

java synchronized锁对象,当对象引用是null的时候,锁的是什么?

volatile是为了防止指令重新排序以确保可见性

对于JVM级别,它是为了防止编译器重新排序

同时,对于某些CPU,它们将通过缓存锁或线程来解决缓存可见性

但是,许多CPU已经过优化。由于cache-consistency-MESI的性能开销,采用storebuffer机制进行异步处理,导致了指令的无序执行。这会导致可见性问题。

然后volatile将在CPU级别增加内存屏障,以解决由CPU无序执行引起的可见性问题

java给方法加锁 java中锁的概念 java锁的区别

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。