2.1. CPU 缓存模型

303a300f-70dd-4ee1-9974-3f33affc6574.png
CPU Cache 的工作方式:
先复制一份数据到 CPU Cache 中,当 CPU 需要用到的时候就可以直接从 CPU Cache 中读取数据,当运算完成后,再将运算得到的数据写回 Main Memory 中。但是,这样存在 内存缓存不一致性的问题 !

2.2. 讲一下 JMM(Java 内存模型)

0ac7e663-7db8-4b95-8d8e-7d2b179f67e8.png
volatile 关键字 除了防止 JVM 的指令重排 ,还有一个重要的作用就是保证变量的可见性。
d49c5557-140b-4abf-adad-8aac3c9036cf.png

2.3. 并发编程的三个重要特性

  • 原子性
  • 可见性
  • 有序性

    2.4. 说说 synchronized 关键字和 volatile 关键字的区别

  • volatile 关键字是线程同步的轻量级实现,所以 volatile性能肯定比synchronized关键字要好 。但是 volatile 关键字只能用于变量而 synchronized 关键字可以修饰方法以及代码块 。

  • volatile 关键字能保证数据的可见性,但不能保证数据的原子性。synchronized 关键字两者都能保证。
  • volatile关键字主要用于解决变量在多个线程之间的可见性,而 synchronized 关键字解决的是多个线程之间访问资源的同步性。