java内存模型
一、计算机的高速缓存模型 现在的计算机基本都是多核的,比如我用的8核,上图只有两核。数据最根本当然是存储再硬盘上的,但是硬盘的读取速度很慢。所以都是先将程序运行的数据加载到内存条(RAM中)的。早期的计算机,CPU和RAM是直接交互的,因为早期的CPU的性能还不像现在这样,非常好。有一个叫做摩尔定律的,大概的意思是说现在的科技发展,每间隔18个月,CPU的性能会翻一倍。慢慢的CPU的性能就比RAM高出很多了,这样导致RAM不能很好的发挥CPU的性能。现在的计算机大多都再CPU和RAM之间加了一个CPU高速缓存。但是这个缓存非常贵...如果打开任务管理器,是可以看到的,如下图 二、JMM JAVA内存模型 了解CPU高速缓存模型是因为JMM和它很像,RAM中存放的是一些程序变量。多个线程可能会共享变量。每个线程都有自己额工作内存。共享变量其实是先复制到工作内存中给线程用,最后再线程操作ok后再保存回去的。但是线程A,B,C如果共享了同一个变量,再不做任何代码级别的操作的时候,他们之间的共享变量副本是不会互相感知的,这个时候就可能出现线程安全相关的问题了。比如下面的代码示例 package com.lyb.jmm; /** * @ClassName Jmm * @Description * @Author Lyb * @Date 2019/12/4 13:48 * @Version