提到Java并发编程,逃不掉一个关键"人物"-------->>volatile关键字。
在看过一些并发书籍和大量帖子文章后,我也斗胆提起写下关于volatile的一些理解与心得。
Q1:请你谈谈对Volatile关键字的理解?
1.保证可见性
2.保证有序性,禁止指令重排
3.不保证原子性(需要借助synchronized或者CAS)
初识JMM
Java内存模型(JavaMemoryModel)描述了Java程序中各种变量(线程共享变量)的访问规则,以及在JVM中将变量,存储到内存和从内存中读取变量这样的底层细节。
JMM有以下规定:
所有的共享变量都存储于主内存,这里所说的变量指的是实例变量和类变量,不包含局部变量,因为局部变量是线程私有的,因此不存在竞争问题。
每一个线程还存在自己的工作内存,线程的工作内存,保留了被线程使用的变量的工作副本。
线程对变量的所有的操作(读,取)都必须在工作内存中完成,而不能直接读写主内存中的变量
不同线程之间也不能直接访问对方工作内存中的变量,线程间变量的值的传递需要通过主内存中转来完成。
本地内存和主内存的关系
正是因为这样的机制,才导致了可见性问题的存在,那我们就讨论下可见性的解决方案。
为什么加锁可以解决可见性问题呢?
因为某一个线程进入synchronized代码块前后,线程会获得锁,清空工作内存,从主内存拷贝共享变量最新的值到工作内存成为副本,执行代码,将修改后的副本的值刷新