Java内存模型(Java Memory Model简称JMM)

什么是JMM模型?

Java内存模型(Java Memory Model简称JMM)

JMM是围绕

原子性,有序性、可见性展开

volatile关键字保证可见性(会把主内存最新值刷到各个线程)和有序性(关键字能禁止指令重排,所以一定程度上保证了有序性)

synchronized和Lock实现原子性(原子性和可见性)

可见性问题

Java内存模型(Java Memory Model简称JMM)_第1张图片

Java内存模型(Java Memory Model简称JMM)_第2张图片 

 

主内存(所有线程共享的)

工作内存(针对本线程的)

如 count=1 刚刚开始在主内存,然后其他线程也复制一份,然后线程1复制后,把count=1 改为count=2,这个时候,线程2 并不知道这个修改,因为线程1这个变更没有刷到主内存,所以其他线程也不知道,要解决共享对象可见性这个问题,我们可以使用java volatile关键字或者是加锁(直接读取主内存的最新的)

ThreadLocal(其实就是每个线程共享变量的副本)

如果线程A与线程B之间要通信的话,必须要经历下面2个步骤。

1)线程A把本地内存A中更新过的共享变量刷新到主内存中去。

2)线程B到主内存中去读取线程A之前已更新过的共享变量。

java内存模型规定了所有的变量都存储在主内存。每条线程还有自己的工作内存,线程的工作内存中保存了被改线程使用到的变量的主内存副本拷贝。线程对变量的所有操作都必须在工作内存中进行,而不能直接读写主内存中的变量。不同线程之间也无法直接访问对方工作内存中的变量,线程间变量传递均需要通过主内存来完成。当多个线程操作的变量涉及到同一个主内存区域,将可能导致各自的工作线程数据不一致,这样就导致变量同步回主内存的时候可能冲突导致数据丢失

你可能感兴趣的:(new,JMM,JMM,Java内存模型)