[Java 面试] 多线程1

一.锁策略

1.你是如何理解悲观锁和乐观锁的 , 具体怎么实现的

悲观锁 : 多个线程访问同一个共享变量冲突的概率较大 , 会在每次访问共享变量之前都去真正加锁

乐观锁 : 多个线程访问同一个共享变量冲突的概率不大 , 并不会真正加锁 , 而是直接尝试访问数据 , 在访问的同时识别当前的数据是否出现冲突

悲观锁的是实现就是先加锁 (借助操作系统的 mutex) , 获取到锁再操作数据 , 获取不到就等待

乐观锁的实现是引入一个版本号 , 借助版本号识别出当前数据访问是否冲突

2.介绍以下读写锁

读写锁就是把读操作和写操作分别进行加锁

读写锁最主要哟个在 "频繁读 , 不频繁写" 的场景中

3.什么是自旋锁 , 为什么要使用自旋锁策略 , 缺点是什么

如果获取锁失败 , 立即再尝试获取锁 , 无限循环 , 直到获取到锁为止 ; 一旦锁被其他线程释放 , 就能第一时间获取到锁

相比于挂起等待锁 :

优点 : 没有放弃 CPU 资源 , 一旦锁被释放就能第一时间捕获 , 更高效 , 在锁持有时间比较短的场景下有用

缺点 : 如果锁的持有时间较长 , 就会浪费 CPU 资源

4.synchronized 是可重入锁么?

是可重入锁

可重入值的是连续两次加锁不会导致死锁

实现方式是 在锁中记录该锁持有的线程身份 , 以及一个计数器(记录加锁次数) , 如果发现当前加锁的线程就是持有锁的线程 , 计数器自增

二.CAS

1.讲解一下 CAS 机制

全程 Compare And Swap , 比较和交换 , 相当于通过一个原子的操作 , 同时完成 "读内存 , 比较是否相等 , 修改内存" 这三个步骤 , 本质上需要 CPU 指令的支撑

2.ABA 问题怎么解决

三.synchronized

1.什么是偏向锁

2.synchronized 实现原理

详情见下文的章节二

https://blog.csdn.net/Boop_wu/article/details/155161052?sharetype=blog&shareId=155161052&sharerefer=APP&sharesource=boop_wu&sharefrom=linkhttps://blog.csdn.net/Boop_wu/article/details/155161052?sharetype=blog&shareId=155161052&sharerefer=APP&sharesource=boop_wu&sharefrom=link

相关推荐
Anastasiozzzz21 分钟前
Java Lambda 揭秘:从匿名内部类到底层原理的深度解析
java·开发语言
骇客野人23 分钟前
通过脚本推送Docker镜像
java·docker·容器
刘琦沛在进步25 分钟前
【C / C++】引用和函数重载的介绍
c语言·开发语言·c++
机器视觉的发动机36 分钟前
AI算力中心的能耗挑战与未来破局之路
开发语言·人工智能·自动化·视觉检测·机器视觉
铁蛋AI编程实战40 分钟前
通义千问 3.5 Turbo GGUF 量化版本地部署教程:4G 显存即可运行,数据永不泄露
java·人工智能·python
HyperAI超神经44 分钟前
在线教程|DeepSeek-OCR 2公式/表格解析同步改善,以低视觉token成本实现近4%的性能跃迁
开发语言·人工智能·深度学习·神经网络·机器学习·ocr·创业创新
晚霞的不甘1 小时前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频
SunnyDays10111 小时前
使用 Java 冻结 Excel 行和列:完整指南
java·冻结excel行和列
R_.L1 小时前
【QT】常用控件(按钮类控件、显示类控件、输入类控件、多元素控件、容器类控件、布局管理器)
开发语言·qt
Zach_yuan1 小时前
自定义协议:实现网络计算器
linux·服务器·开发语言·网络