多线程生成的缘由(Java内存模型与i++操做解析)

Java 内存模型


线程之间的共享变量存储在主内存(main memory)中,每一个线程都有一个私有的本地内存(local memory),本地内存中存储了该线程以读/写共享变量的副本。缓存

本地内存是JMM(Java内存模型)的一个抽象概念,并不真实存在。它涵盖了缓存,写 缓冲区,寄存器以及其 他的硬件和编译器优化。Java内存模型的抽象示意图以下图:多线程

输入图片说明

i++操做实质


对于一个简单的 i++ 操做,结合上图1 ,会发生以下的步骤:优化

  • read:做用于主内存中,把主内存中一个变量的值传输到 工做内存 中。
  • load:做用于工做内存,把从read 操做从主内存中获得的值放入到工做内存的副本中。
  • use:把工做内存中的该副本值传递给执行引擎(也就是操做数栈中)。
  • assign:做用于工做内存,把执行引擎执行后的新值传递给该工做内存的变量。
  • store:做用于工做内存,把工做内存中该变量的值传送到 主内存中去。
  • write:做用于主内存的变量,把store 操做 获得的值写入到 主内存的该变量中。

因此说,一个 i++操做并非原子性的。这上述的这些步骤中,可能会有其余线程对主内存的变量进行操做,从而致使出现多线程问题。线程

相关文章
相关标签/搜索