JMM是如何保证原子性呢?

3.3.1加锁

锁是一种通用技术,比如Java提供的Synchronized关键字就是锁的一种实现,Synchronized是排他锁 /独占锁,就是有你没我的意思,只要其他线程到来访问,发现锁还未释放,就要在外面等待,因为Synchronized保证在同一时间内只有一个线程能够操作数据,其保证了原子性。

3.3.2原子变量(并发量少的情况)

在java.util.concurrent下,可以发现有atomic包,它可以解决原子性问题,加锁是阻塞式方式,而原子变量是非阻塞方式。

原子类(比如AtomicInteger):原子类的原子性是通过volatile+CAS实现原子操作的,volatile为CAS的实现提供了基础。

相关推荐
Tapdata14 分钟前
拒绝停服,随时回退:MS SQL 到 ≈ 的无缝数据库双向迁移方案
数据库
失败又激情的man25 分钟前
python爬虫之数据存储
前端·数据库·python
遗忘妳29 分钟前
mysql高可用
数据库·mysql
小灰灰搞电子42 分钟前
Qt多线程访问同一个数据库源码分享(基于Sqlite实现)
数据库·qt·sqlite
麓殇⊙1 小时前
redis--黑马点评--Redisson快速入门
数据库·redis·缓存
爱思德学术1 小时前
DBLP数据库是什么?
数据库
onlooker66661 小时前
Go 语言底层(四) : 深入 Context 上下文
开发语言·数据库·golang
岁忧1 小时前
MySQL中【正则表达式】用法
数据库·mysql·正则表达式
浠寒AI2 小时前
PostgreSQL 与 SQL 基础:为 Fast API 打下数据基础
数据库·sql·postgresql
金州饿霸2 小时前
MySQL--慢查询日志、日志分析工具mysqldumpslow
数据库·mysql