Java 多线程1:多线程生成的原因(Java内存模型与i++操作解析)
来源:互联网 发布:根据ip地址查域名 编辑:程序博客网 时间:2024/05/16 01:00
Java 内存模型
线程之间的共享变量存储在主内存(main memory)中,每个线程都有一个私有的本地内存(local memory),本地内存中存储了该线程以读/写共享变量的副本。
本地内存是JMM(Java内存模型)的一个抽象概念,并不真实存在。它涵盖了缓存,写 缓冲区,寄存器以及其 他的硬件和编译器优化。Java内存模型的抽象示意图如下图:
i++操作实质
对于一个简单的 i++ 操作,结合上图1 ,会发生如下的步骤:
read:作用于主内存中,把主内存中一个变量的值传输到 工作内存 中。
load:作用于工作内存,把从read 操作从主内存中得到的值放入到工作内存的副本中。
use:把工作内存中的该副本值传递给执行引擎(也就是操作数栈中)。
assign:作用于工作内存,把执行引擎执行后的新值传递给该工作内存的变量。
store:作用于工作内存,把工作内存中该变量的值传送到 主内存中去。
write:作用于主内存的变量,把store 操作 得到的值写入到 主内存的该变量中。
所以说,一个 i++ 操作并不是原子性的。这上述的这些步骤中,可能会有其他线程对主内存的变量进行操作,从而导致出现多线程问题。
0 0
- Java 多线程1:多线程生成的原因(Java内存模型与i++操作解析)
- Java内存模型与多线程
- java内存模型与多线程
- java内存模型与多线程
- Java内存模型与多线程
- Java内存模型与多线程
- Java 多线程:多线程生成的原因z
- 【Java多线程】Java内存模型与Volatile
- java多线程内存模型
- Java多线程内存模型
- java 多线程内存模型
- Java多线程内存模型
- java内存模型-多线程
- Java多线程--内存模型
- [Java 并发]多线程同步与Java内存模型(二)
- java多线程与内存模型(一)
- 3.31 java多线程与内存模型
- Java内存模型与多线程数据可见性和操作的有序性
- 使用 python 实现 Voronoi 图
- 51nod 1277 字符串中的最大值
- LintCode-二叉树的层次遍历
- 从嵌入式系统到信息物理系统
- spring中一些关键字@controller @service @component component-scan配置
- Java 多线程1:多线程生成的原因(Java内存模型与i++操作解析)
- 统计学学习笔记
- 【蓝桥杯 第七届省赛试题 抽签】
- windows系统同时连接多个openvpn账户
- qnx的HMI方案及其GUI方案比较-基于QNX的HMI平台和方案
- codevs 1026_逃跑的拉尔夫_bfs
- 制作Hololens中一直面向用户的面板,不是UI,而是类似公告板
- ArrayList从源码上看其线程安全问题(jdk1.8)
- AssetBundleManager