1、JMM Java Memory Model (java内存模型)
并发过程中如何处理可见性、原子性、有序性的问题
使用多线程Runnable/ Thread
并发编程中的两个关键问题
-
线程之间如何通信:
wait()
notify()
notifyall()a,共享内存 – 隐式通信
b,消息传递 – 显式通信 -
线程之间如何同步
在共享内存的并发模型中,同步是显式做的;synchronized
在消息传递的并发模型中,由于消息的发送必须在消息的接收之前,所以同步是隐式
区别
a) 对于声明了Volatile的变量进行写操作的时候,JVM会向处理器发送一条Lock前缀的指令,会把这个变量所在缓存行的数据写回到系统内存。
b) 在多处理器的情况下,保证各个处理器缓存一致性的特点,就会实现缓存一致性协议。
Synchronized:可重入锁、互斥性、可见性。
Volatile 可以做到原子性、可见性;不能做到复合操作的原子性。