public class Test {
    public static void main(String[] args){

    }
}

/*
    12.3 Java内存模型

    Java内存模型定义了线程与主内存之间的抽象关系:
        1.共享变量存储于主内存之中,每个线程都可以访问
        2.每个线程都有私有的工作内存
        3.工作内存只存储该线程对共享变量的副本
        4.线程不能直接操作主内存,只有先操作了工作内存之后才能写入主内存
        5.工作内存是一种抽象的概念,涵盖了缓存、寄存器、编译优化以及硬件
 */

/*
    13.1 并发编程的三个重要特性
        原子性:一次操作或者多次操作,要么所有的惭怍全部都得到了执行,并且不受任何
            因素的干扰而中断,要么所欲的操作都不执行
        可见性:当一个线程对共享变量进行了修改,那么另外的线程可以立即看到。
        有序性:程序代码在执行过程中的先后顺序。在多线成的情况下,如果有序性得不到
            保障,其结果是灾难性的。

    13.2.1 JMM与原子性

    y=x;
        1.执行线程从主内存读取x的值(如果x已经存在与执行线程的工作内存中,则直接获取)
            然后将其存入当前线程的工作内存中。
        2.在执行线程的工作内存中修改y的值为x。

    结论:
        1.多个原子性的操作在一起就不再是原子性操作了
        2.简单的读取与赋值操作是原子性的,将一个变量赋给另一个变量不是原子的
        3.JMM只保证了基本读取和赋值的原子性操作
 */

/*
    13.2.2 JMM与可见性

    Java三种方式保证可见性:
        1.使用关键字volatile,读,写两个方面
        2.使用关键字synchronized,同一时刻只有一个线程获得锁,且释放锁之前,
            会将对变量的修改刷新到主内存中
        3.通过JUC提供的显式锁Lock
 */

/*
    13.2.3 JMM与有序性

    方案同上。

    JMM具备一些天生的有序性规则,不需要任何同步手段就能够保证有序性,这个规则被称为
    Happens-before原则。如果两个操作的执行次序无法从happens-before原则推导出来,
    那么它们就无法保证有序性,也就是说JVM或者处理器可以任意对它们进行重排序出来。

    happens-before原则:
        1.程序次序原则:一个线程内,代码按照编写时的次序来执行,编写在后面的操作发生
            在编写在前面的操作之后。(JVM还是可能对程序代码进行重排序,只要确保一个
            线程内结果一致即可)
        2.锁定规则:一个unlock操作要先行发生于对同一个锁的lock操作。
        3.volatile变量原则:对一个变量的写操作要早与对这个变量的读操作。
        4.传递规则:如果操作a先于操作b,而操作b先与操作c,则可以得出操作a肯定先于
            操作c。happens-before原则具有传递性
        5.线程启动规则:Thread对象的start()方法先行于发生对该线程的任何动作。
        6.线程中断规则:对线程执行interrupt()方法肯定优先与捕获到中断信号。
        7.线程终结原则:线程任务的执行、逻辑单元执行肯定要发生于线程死亡之前
        8.一个对象初始化的完成先于finalize()方法之前。
 */

/*
    13.3.1 volatile关键字语义

    被volatile修饰的变量有:
        1.保证了不同线程之间对共享变量操作时的可见性
        2.进制对指令进行重排序操作

    (1)理解volatile保证可见性
    (2)理解volatile保证顺序性
    (3)理解volatile不保证原子性
        我觉得作者在将volatile不保证原子性时,举得例子前后都是矛盾的,前面一个例子都说了
        volatile在工作内存中对变量进行了修改后,会立即刷新到主内存中,导致其他工作内存中
        的备份失效。但是这个例子时又说线程B工作内存中为i执行了加1的操作,但是未刷新到至主
        内存中,这不是在搞笑么。这个例子又用到了后面写的类,我想做个实验都做不成,唉!
 */

/*
    13.3.3 volatile的使用场景

    (1)开关控制利用可见性的特点
            class ThreadConseale extends Thread{
                private volatile boolean started = true;

                public void run(){
                    while(started){
                        //do work
                    }
                }

                public void shutdown(){
                    this.started=false;
                }
            }
    (2)状态标记利用顺序性特点
    (3)Singleton设计模式的double-check也是利用顺序性特点。
 */

《Java高并发编程详解》笔记

Java volatile关键字小结的更多相关文章

  1. [Java并发编程(三)] Java volatile 关键字介绍

    [Java并发编程(三)] Java volatile 关键字介绍 摘要 Java volatile 关键字是用来标记 Java 变量,并表示变量 "存储于主内存中" .更准确的说 ...

  2. 13、Java并发性和多线程-Java Volatile关键字

    以下内容转自http://tutorials.jenkov.com/java-concurrency/volatile.html(使用谷歌翻译): Java volatile关键字用于将Java变量标 ...

  3. Java Volatile关键字(转)

    出处:  Java Volatile关键字 Java的volatile关键字用于标记一个变量“应当存储在主存”.更确切地说,每次读取volatile变量,都应该从主存读取,而不是从CPU缓存读取.每次 ...

  4. Java volatile 关键字底层实现原理解析

    本文转载自Java volatile 关键字底层实现原理解析 导语 在Java多线程并发编程中,volatile关键词扮演着重要角色,它是轻量级的synchronized,在多处理器开发中保证了共享变 ...

  5. Java volatile关键字详解

    Java volatile关键字详解 volatile是java中的一个关键字,用于修饰变量.被此关键修饰的变量可以禁止对此变量操作的指令进行重排,还有保持内存的可见性. 简言之它的作用就是: 禁止指 ...

  6. Java Volatile关键字

    在当前的Java内存模型下,线程可以把变量保存在本地内存(比如机器的寄存器)中,而不是直接在主存中进行读写. 这就可能造成一个线程在主存中修改了一个变量的值,而另外一个线程还继续使用它在寄存器中的变量 ...

  7. 从根源上解析 Java volatile 关键字的实现

    1.解析概览 内存模型的相关概念 并发编程中的三个概念 Java内存模型 深入剖析Volatile关键字 使用volatile关键字的场景 2.内存模型的相关概念 缓存一致性问题.通常称这种被多个线程 ...

  8. java volatile关键字解析

    volatile是什么 volatile在java语言中是一个关键字,用于修饰变量.被volatile修饰的变量后,表示这个变量在不同线程中是共享,编译器与运行时都会注意到这个变量是共享的,因此不会对 ...

  9. Java Volatile关键字 以及long,double在多线程中的应用

    概念: volatile关键字,官方解释:volatile可以保证可见性.顺序性.一致性. 可见性:volatile修饰的对象在加载时会告知JVM,对象在CPU的缓存上对多个线程是同时可见的. 顺序性 ...

随机推荐

  1. 关于EF ORM 框架的使用问题

    1.无法更新 EntitySet“System_UserInfo20140218001”,因为它有一个 DefiningQuery,而 <ModificationFunctionMapping& ...

  2. Delphi 编写ActiveForm窗体工程知识和样例(开发浏览器客户端应用程序)(有详细步骤)

    一.基础知识介绍: 1.ActiveForm的基础知识介绍: 在Delphi中,ActiveForm是封装了Delphi Form的一种ActiveX控件.ActiveForm其实是一种标准的Delp ...

  3. Delphi事件的广播

    原文地址:Delphi事件的广播 转作者:MondaySoftware 明天就是五一节了,辛苦了好几个月,借此机会应该尽情放松一番.可是想到Blog好久没有写文章,似乎缺些什么似的.这几个月来在项目中 ...

  4. 一次C#和C++的实际应用性能比较(C++允许我们使用任何手段来提高效率,只要愿意做出足够的努力)

    05年时,在微软的Rico Mariani做了一次实际应用的C#和C++的性能比较.事情起源于微软著名的元老Raymond Chen(在下敬仰的超级牛人)用C++写了一个英汉词典程序,来描述讲解优化C ...

  5. ASP.NET 5 牛刀小試(二):加入第三方 DI 容器

    上回介绍了 ASP.NET vNext 自带容器的基本用法,这次要试试把 ASP.NET vNext 的自带容器换成 Autofac. 这一次,在编写范例程序的过程中,光是解决 KRE 与相关套件的版 ...

  6. 【canvas】高级功能一 变形

    [canvas]Demo1 scale缩放 <!DOCTYPE html> <html lang="en"> <head> <meta c ...

  7. ABP开发框架前后端开发系列---(10)Web API调用类的简化处理

    在较早期的随笔<ABP开发框架前后端开发系列---(5)Web API调用类在Winform项目中的使用>已经介绍了Web API调用类的封装处理,虽然这些调用类我们可以使用代码生成工具快 ...

  8. 【转】Linux下添加FTP账号和服务器、增加密码和用户,更改FTP目录

    转自:http://blog.csdn.net/cloudday/article/details/8640234   1. 启动VSFTP服务器 A:cenos下运行:yum  install  vs ...

  9. spring boot + druid + mybatis + atomikos 多数据源配置 并支持分布式事务

    文章目录 一.综述 1.1 项目说明 1.2 项目结构 二.配置多数据源并支持分布式事务 2.1 导入基本依赖 2.2 在yml中配置多数据源信息 2.3 进行多数据源的配置 三.整合结果测试 3.1 ...

  10. spring boot 2.x 系列——spring-boot 集成 Swagger2 打造在线接口文档

    文章目录 一.Springfox 与 Swagger 简介 1.1 Springfox 1.2 Swagger 1.3 OpenApi.Swagger.Springfox的关系 二.spring bo ...