zoukankan      html  css  js  c++  java
  • 010 并发的三个特性

    一 . 概述

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


    二 . 可见性

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

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

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

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


    三. 有序性

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

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

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


    四 . 问题的解决

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

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

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

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

  • 相关阅读:
    菜鸟学存储:网络存储IP SAN与IB SAN
    读xml高手
    预先加载图片
    xred520
    最简单准确的硬盘整数分区设置操作方法
    Google 每天处理约 20000TB 的数据
    IE 8 无法正常使用网站后台编辑器问题
    常用的JS技术1
    adodb stream 使用说明
    [Tools] JDGUI(Java Decompiler)
  • 原文地址:https://www.cnblogs.com/trekxu/p/9523799.html
Copyright © 2011-2022 走看看