Java后端八股-------并发编程





















图中的 synchronized方法如果没有锁,那么可能会有超卖,数据错误等情况。

加锁之后会按顺序售卖。

synchronized的底层是monitor。



线程没有竞争关系的时候,引入了轻量级锁,当需要处理竞争关系的时候一定要用到重量级锁(线程的对象锁)。


mark word中重量级锁时,ptr_to_heavyweight_monitor是一个指向monitor的指针。

cas交换是用来保证原子操作的.

👆cas会做交换,交换地址值,这样其他线程就无法获取锁,但是自己的线程内可以多次获取锁(没有竞争关系时)。


在Java中,轻量级锁(Lightweight Locking)和偏向锁(Biased Locking)是Java虚拟机(JVM)内部实现的锁优化技术,它们旨在提高多线程环境下锁的性能。这些锁策略是JVM自动管理的,通常不需要开发者手动开启或关闭。

线程里面的工作内存不存在线程安全的问题,共享变量副本是主内存中共享变量的副本,需要通过JMM控制进行save和load






👆在上面这段代码中,线程1修改的stop为true,线程2是能读到的,但是线程3while循环却不停止。


JVM优化导致的重排序。

实验数据

👆这个可以解决问题

👆这个不能组织x在y后执行,不能解决问题。




AQS的实现类当中,公平锁和非公平锁都有实现。













一把锁,获取效率很低

每个hash值都有一把锁。





相关推荐
知识分享小能手2 小时前
Redis入门学习教程,从入门到精通,Redis 概述:知识点详解(1)
数据库·redis·学习
xixihaha13244 小时前
将Python Web应用部署到服务器(Docker + Nginx)
jvm·数据库·python
夕除4 小时前
Mysql--07
数据库·mysql
数据最前线4 小时前
5个瞬间,盘点国产数据库的2025年
数据库
jiankeljx4 小时前
Redis-配置文件
数据库·redis·oracle
美好的事情能不能发生在我身上4 小时前
Hot100中的:贪心专题
java·数据结构·算法
xixihaha13244 小时前
Python游戏中的碰撞检测实现
jvm·数据库·python
myloveasuka5 小时前
Java与C++多态访问成员变量/方法 对比
java·开发语言·c++
Schengshuo5 小时前
SQL 中 COUNT 的用法详解
数据库·sql
顶点多余5 小时前
Mysql--后端与前端关系
数据库·mysql