说说对JVM 内存模型的理解
● 谈Java的内存模型,就得先谈谈 CPU的多级缓存模型。
● CPU的数据不是直接读取内存的。因为CPU的速度,相较于内存,快了几百倍。而是从缓存进行读取的,如果缓存中没有,就把数据从内存中拿到缓存中。【缓存的命中率是很高的】CPU读写的时候,只操作缓存里的数据,计算完了之后,再把数据写回到内存中。
● JMM就是对CPU多级缓存模型的封装。这样就能实现“一次编译,处处运行”,屏蔽了不同硬件的差异。
● 现在的CPU都是多核的,那么缓存就有多个,A 缓存里面的数据被修改了,但是其他缓存并不知道,这时候这会出现数据不一致的问题。
● JMM设计出来,就是想解决多线程下线程安全的问题,实现数据的一致性
● Java内存模型的主体结构:
○ 一个主内存和多个工作内存
○ 主内存是主线程使用的,每个子线程使用自己的工作内存。
○ 子线程不能直接使用主内存中的数据,需要先拷贝一份到自己的工作内存中。然后子线程操作的就是自己工作内存中的数据副本。操作完了之后,再把这个数据写回主内存中。
● Java内存模型可不是一个物理上的结构,内存条中可没有什么主内存,工作内存什么的。它只是JVM制定出来的一套规范,Java内存模型,就是对CPU,寄存器,三级缓存,内存,做的一个封装,一个抽象。