首先我们都知道多线程在获取共享资源时,往往会出现意想不到的结果,这是为什么呢?线程获取共享资源的过程如下图:
首先我们需要了解jvm内存结构,在这里不过多说明,由上图我们可以知道,在jvm内存中分为独立内存和共享内存,独立内存是我们每个线程独有的信息,而共享内存就是我们每个线程都可以访问的数据,由于线程在获取共享数据的时候是一个过程,有左部分图我们可以知道,首先我们获取共享数据读取到每个线程的缓存空间,然后进行加载读取赋值写入同步等操作,在多线程并发访问时我们如果一个线程获取了堆内存中的数据,此时其他线程也访问此共享数据,我们第一个线程数据还没有修改更新到堆内存中,那么第二个线程此时读取数据就是脏数据。我们如果加上了Synchronizer等同于把我们执行过程作为一个整体,直接读取堆内存数据不在读取缓存,这样我们就可以实时获取最新数据,那么volatile怎么回事呢?它是直接读取堆内存数据,也就是我们常说的可见性,但是他并没有处理我们线程获取的原子性。