什么是JMM模型?
Java内存模型(Java Memory Model简称JMM)
JMM是围绕
原子性,有序性、可见性展开
volatile关键字保证可见性(会把主内存最新值刷到各个线程)和有序性(关键字能禁止指令重排,所以一定程度上保证了有序性)
synchronized和Lock实现原子性(原子性和可见性)
主内存(所有线程共享的)
工作内存(针对本线程的)
如 count=1 刚刚开始在主内存,然后其他线程也复制一份,然后线程1复制后,把count=1 改为count=2,这个时候,线程2 并不知道这个修改,因为线程1这个变更没有刷到主内存,所以其他线程也不知道,要解决共享对象可见性这个问题,我们可以使用java volatile关键字或者是加锁(直接读取主内存的最新的)
ThreadLocal(其实就是每个线程共享变量的副本)
如果线程A与线程B之间要通信的话,必须要经历下面2个步骤。
1)线程A把本地内存A中更新过的共享变量刷新到主内存中去。
2)线程B到主内存中去读取线程A之前已更新过的共享变量。
java内存模型规定了所有的变量都存储在主内存。每条线程还有自己的工作内存,线程的工作内存中保存了被改线程使用到的变量的主内存副本拷贝。线程对变量的所有操作都必须在工作内存中进行,而不能直接读写主内存中的变量。不同线程之间也无法直接访问对方工作内存中的变量,线程间变量传递均需要通过主内存来完成。当多个线程操作的变量涉及到同一个主内存区域,将可能导致各自的工作线程数据不一致,这样就导致变量同步回主内存的时候可能冲突导致数据丢失