浅谈java多线程中的内存可见性
2017-11-14 22:23
148 查看
何谓可见性?
即一个线程对共享变量的修改能够及时被其它线程看到。
*所有的变量都存在主内存中。
*每个线程都有自己独立的工作内存,里面保存该线程使用到的变量副本(主内存中该变量的一份拷贝)。
*线程对共享变量的所有操作都必须在自己的工作内存中进行,而不能在主内存中进行读写。
*不同线程之间无法直接访问其他线程工作内存中的变量,线程之间变量值的传递需要在主内存中进行。
可见性实现原理
线程1对共享变量想被线程2看到需要进行以下操作
*1.把工作内存中更新的共享变量及时刷新到主内存中
*2.将主内存中最新的共享变量值更新到工作内存2中
java语言层面实现可见性的两种方式
*1.synchnoized
*2.volatile
下面我们来主要介绍[b]synchnoized[/b]
[b]synchnoized实现可见性:
[/b]
synchnoized能够实现:原子性(同步),可见性
[b][b]JMM关于[b]synchnoized的两条规定:[/b][/b][/b]
*1.线程解锁之前必须把共享变量的最新值刷新到主内存中
*2.线程加锁时将清空工作内存中共享变量的值,从而是共享变量时需要从主内存中重新读取最新的共享变量的值(注意:加锁与解锁需要时同一把锁)
*3.线程解锁前对共享变量的修改在下次加锁时对其他线程可见。
[b][b][b]执行的完整流程:[/b][/b][/b]
*1.获得互斥锁
*2.清空工作内存
*3.从主内存中拷贝最新的变量副本到工作内存中
*4.执行代码
*5.将更改后的共享变量值刷新到主内存中
*6.释放互斥锁
相关文章推荐
- java多线程的内存可见性探索_1
- 浅谈Java多线程的同步问题
- Java 细说多线程之内存可见性
- Java基础复习一之多线程(并发,内存模型)
- java多线程之内存可见性-synchronized、volatile
- java多线程之内存可见性学习笔记
- 浅谈多线程在java程序中的应用
- 浅谈Java之内存回收
- 线程,多线程,Java内存区域
- Java多线程之内存可见性
- 浅谈Java内存及GC
- java多线程内存可见性分析
- java中多线程 内存模型和数据同步的一些要点
- 浅谈java+内存分配及变量存储位置的区别
- Java实现内存可见性的两种方法比较:synchronized 和 Volatile以及涉及到锁的剖析
- NIO--JAVA NIO之浅谈内存映射文件原理与DirectMemory
- 浅谈java内存泄漏
- Java多线程之内存可见性
- java多线程之内存可见性学习笔记
- jvm住内存与工作内存,内存模型反映的java多线程问题