Java volatile关键字分析

每个线程创建时,JVM会为其创建一份私有的工作内存(栈空间),不同线程的工作内存之间不能直接互相访问
JMM规定所有的变量都存在主内存,主内存是共享内存区域,所有线程都可以访问
线程对变量进行读写,会从主内存拷贝一份副本到自己的工作内存,操作完毕后刷新到主内存。所以,线程间的通信要通过主内存来实现。
volatile的作用是:线程对副本变量进行修改后,其他线程能够立刻同步刷新最新的数值。这个就是可见性。

结构图如下:

能够保存可见性,但不能保持原子性,如果变量有先后顺序的话可能会发现运行错误

相关推荐
龘龍龙3 分钟前
Python基础(八)
开发语言·python
期待のcode23 分钟前
@RequestBody的伪表单提交场景
java·前端·vue.js·后端
气π37 分钟前
【JavaWeb】——(若依+AI)-帝可得实践项目
java·spring
幺零九零零1 小时前
Golang-Swagger
开发语言·后端·golang
乌暮1 小时前
JavaEE初阶--多线程案例
java·java-ee
小光学长1 小时前
基于ssm旅游管理系统的开发与设计z050cft7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·旅游
用户3521802454751 小时前
🥯2025 年终极避坑指南:Spring Boot 2.7 + 3.2 混合集群的 Redis + OAuth2 序列化血泪史
java·后端·spring cloud
陌路物是人非1 小时前
记一个 @Resource BUG
java·开发语言·bug
JQShan1 小时前
同步的 defer,异步的陷阱:Swift 并发中加载动画关不掉的调试实录
性能优化·swift
怎么就重名了1 小时前
记录Qt的UDP通信丢包问题
开发语言·qt·udp