010 并发的三个特性

一 . 概述

  在之前,我们使用synchronized关键词解决了原子性的操作,本节我们分析一个JVM内存模型导致的另外的两个问题.


二 . 可见性

  为了加速线程的运行的速度,JVM的内存模型中设置了线程栈中的缓存,当一个线程使用了堆内存的数据的时候,首先会将这个数据缓存到线程栈之中,

  当这个数据是共享的数据,当一个线程对其进行了修改,那么这个数据并不会及时的回写到堆内存之中,

  这样,就出现了可见性问题.

  所谓的可见性问题就是缓存和主存之间的不一致,导致可能出现线程的安全性问题.


三. 有序性

  为了更好的加速线程的执行速度,java在编译和运行的时候使用CPU指令乱序的方式进行指令的运行.

  因此,在多线程之中我们的代码可能不会按照代码的真实顺序运行.

  当这种情况发生的时候,就有可能出现线程的安全性问题.


四 . 问题的解决

  在前面,我们使用了synchronized关键词实现了原子性,其实另外也实现了可见性和有序性,因此,当我们使用synchronized关键词就能完成线程的安全性问题.

  但是,synchronized关键词的粒度是非常大的,有的时候我们仅仅只需要保证可见性和有序性就能解决这个问题.

  在java之中出现了这个关键词,volatile关键词.

  在下一节,我们来说明这个关键词的一些作用

原文地址:https://www.cnblogs.com/trekxu/p/9523799.html