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

    一 . 概述

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


    二 . 可见性

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

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

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

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


    三. 有序性

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

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

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


    四 . 问题的解决

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

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

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

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

  • 相关阅读:
    saxbuilder用法
    【转】开篇python--明白python文件如何组织,理解建立源文件
    [转]linux awk命令详解
    sed 指定行范围匹配(转)
    MySQL Error Code文档手册---摘自MySQL官方网站
    java文件读写操作大全
    详解coredump
    Java中Map根据键值(key)或者值(value)进行排序实现
    java如何对map进行排序详解(map集合的使用)
    遍历Map的四种方法
  • 原文地址:https://www.cnblogs.com/trekxu/p/9523799.html
Copyright © 2011-2022 走看看