资讯专栏INFORMATION COLUMN

【Java并发编程的艺术】第二章读书笔记之volatile关键字

szysky / 1502人阅读

摘要:目前看的部分主要是这个关键字。语言提供了,保证了所有线程能看到共享变量最新的值。前缀的指令在多核处理器下会做两件事情将当前处理器缓存行的数据写回到系统内存。

这一章节的话,主要是讲一下在并发操作中常见的volatile、synchronized以及原子操作的相关知识。

目前看的部分主要是volatile这个关键字。

volatile

根据Java语言规范第3版中对volatile的定义:

Java编程语言允许线程访问共享变量,为了确保共享变量能被准备和一致地更新,线程应该确保通过排他锁多带带获得这个变量。

Java语言提供了volatile,保证了所有线程能看到共享变量最新的值。

在硬件层面的话,如果说一个变量使用volatile去修饰的话,JIT编译器生成的汇编指令中会含有Lock前缀的指令。Lock前缀的指令在多核处理器下会做两件事情

将当前处理器缓存行的数据写回到系统内存。

写回内存的操作使得在其他CPU里缓存了该内存地址的数据无效。

一般来说为了提高处理器速度,CPU不直接和内存交互,而是将系统内存的数据读到内部缓存再进行操作,但操作完不知道什么时候会写回内存。
如果说是对声明了volatile的变量进行写操作,就会产生这条Lock前缀的指令,把缓存内的数据写回系统内存。但是其他处理器上的值可能还是旧值,因此在多处理器下,会实现缓存一致性协议,每个处理器会嗅探总线上传播的数据检查自己缓存是否有过期,如果过期的话,就把自己内部的缓存行设置为无效,当需要对这个数据进行操作时,就会重新从系统内存读取。

这个是比较底层层面了,如果就Java的内存模型而言,我有以下几点理解。

Java的内存模型中,线程之间通信是通过主内存完成的,针对同一个变量,每个线程都会有它的一个副本。

副本是在线程的局部变量表里,在要对其进行操作,需要将放入操作栈中,如果使用了volatile关键字,其他线程对这个变量进行了修改,在加载副本到操作栈之前,就会发现本地的这个副本已经失效了,之后就去主内存再读取。从而保证了共享变量在多个线程之间的可见性,即一个线程对共享变量的修改,其他的线程可以及时感知到。

在JDK后来的更新中,volatile还增加了新的作用,禁止指令重排序,这个得看到具体后面的内容再做记录吧~

下回再见~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/70326.html

相关文章

  • Java并发编程艺术二章读书笔记synchronized键字

    摘要:在之前的文章中学习了关键字,可以保证变量在线程间的可见性,但他不能真正的保证线程安全。线程执行到指令时,将会尝试获取对象所对应的的所有权,即尝试获得对象的锁。从可见性上来说,线程通过持有锁的方式获取变量的最新值。 在之前的文章中学习了volatile关键字,volatile可以保证变量在线程间的可见性,但他不能真正的保证线程安全。 /** * @author cenkailun *...

    GT 评论0 收藏0
  • Java并发编程艺术二章读书笔记原子操作

    摘要:前言今天的笔记来了解一下原子操作以及中如何实现原子操作。概念原子本意是不能被进一步分割的最小粒子,而原子操作意为不可被中断的一个或一系列操作。处理器实现原子操作处理器会保证基本内存操作的原子性。 showImg(https://segmentfault.com/img/bVVIRA?w=1242&h=536); 前言 今天的笔记来了解一下原子操作以及Java中如何实现原子操作。 概念 ...

    olle 评论0 收藏0
  • 那些年我看过书 —— 致敬我大学生活 —— Say Good Bye !

    摘要:开头正式开启我入职的里程,现在已是工作了一个星期了,这个星期算是我入职的过渡期,算是知道了学校生活和工作的差距了,总之,尽快习惯这种生活吧。当时是看的廖雪峰的博客自己也用做爬虫写过几篇博客,不过有些是在前人的基础上写的。 showImg(https://segmentfault.com/img/remote/1460000010867984); 开头 2017.08.21 正式开启我...

    xiaoqibTn 评论0 收藏0
  • Java并发编程艺术】第一章读书笔记

    摘要:前言并发编程的目的是让程序跑的更快,但并不是启动更多的线程,这个程序就跑的更快。尽可能降低上下文切换的次数,有助于提高并发效率。死锁并发编程中的另一挑战是死锁,会造成系统功能不可用。 前言 并发编程的目的是让程序跑的更快,但并不是启动更多的线程,这个程序就跑的更快。有以下几种挑战。 挑战及方案 上下文切换 单核CPU上执行多线程任务,通过给每个线程分配CPU时间片的方式来实现这个机制。...

    马忠志 评论0 收藏0
  • 并发编程艺术

    摘要:假设不发生编译器重排和指令重排,线程修改了的值,但是修改以后,的值可能还没有写回到主存中,那么线程得到就是很自然的事了。同理,线程对于的赋值操作也可能没有及时刷新到主存中。线程的最后操作与线程发现线程已经结束同步。 很久没更新文章了,对隔三差五过来刷更新的读者说声抱歉。 关于 Java 并发也算是写了好几篇文章了,本文将介绍一些比较基础的内容,注意,阅读本文需要一定的并发基础。 本文的...

    curlyCheng 评论0 收藏0

发表评论

0条评论

szysky

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<