包括: 一. Java 内存模型 二. i ++ 操作的实质 三. Java 多线程产生的原因 四. 总结 一. Java 内存模型 线程之间的共享变量存储在主内存(main memory)中,每个线程都有一个私有的本地内存(local memory),本地内存中存储了该线程以读/写共享变量的副本。本地内存是JMM(Java内存模型)的一个抽象概念,并不真实存在。它涵盖了缓存,写 缓冲区,寄存器以及其 他的硬件和编译器优化。Java内存模型的抽象示意图如下图1: 图1 二. i ++ 操作的实质 对于一个简单的 i++ 操作,结合上图1 ,会发生如下的步骤:
三. Java 多线程产生的原因 结合 一 的Java内存模型,和 二 的 i++操作实质,可以发现,并不是每一步都需要使用到 CPU,比如说读取 i,写入 i 的过程中,CPU 此时就空闲下来,此时,为了让CPU 不空闲,则产生了 多线程的技术。 Ps:由上面的模型可以看出,假如有 A,B两个线程 都进行 i++操作,由于上面 i++操作不是原子性的,那么 A,B 的执行顺序 会 对结果有比较大的改变。所以也就会衍生出了一系列的多线程问题的解决方案,如 lock,synchronized,volatile,threadlocal,cas 等。 四. 总结
参考:《深入理解Java虚拟机》P364. |
|
来自: fishpan_oliver > 《待分类》