一 . 概述
在之前,我们使用synchronized关键词解决了原子性的操作,本节我们分析一个JVM内存模型导致的另外的两个问题.
二 . 可见性
为了加速线程的运行的速度,JVM的内存模型中设置了线程栈中的缓存,当一个线程使用了堆内存的数据的时候,首先会将这个数据缓存到线程栈之中,
当这个数据是共享的数据,当一个线程对其进行了修改,那么这个数据并不会及时的回写到堆内存之中,
这样,就出现了可见性问题.
所谓的可见性问题就是缓存和主存之间的不一致,导致可能出现线程的安全性问题.
三. 有序性
为了更好的加速线程的执行速度,java在编译和运行的时候使用CPU指令乱序的方式进行指令的运行.
因此,在多线程之中我们的代码可能不会按照代码的真实顺序运行.
当这种情况发生的时候,就有可能出现线程的安全性问题.
四 . 问题的解决
在前面,我们使用了synchronized关键词实现了原子性,其实另外也实现了可见性和有序性,因此,当我们使用synchronized关键词就能完成线程的安全性问题.
但是,synchronized关键词的粒度是非常大的,有的时候我们仅仅只需要保证可见性和有序性就能解决这个问题.
在java之中出现了这个关键词,volatile关键词.
在下一节,我们来说明这个关键词的一些作用