java中的Volatile和synchronized的区别

1、JMM Java Memory Model (java内存模型)
并发过程中如何处理可见性、原子性、有序性的问题
使用多线程Runnable/ Thread

并发编程中的两个关键问题

  1. 线程之间如何通信:
    wait()
    notify()
    notifyall()

    a,共享内存 – 隐式通信
    java中的Volatile和synchronized的区别_第1张图片
    b,消息传递 – 显式通信

  2. 线程之间如何同步
    在共享内存的并发模型中,同步是显式做的;synchronized
    在消息传递的并发模型中,由于消息的发送必须在消息的接收之前,所以同步是隐式

区别

a) 对于声明了Volatile的变量进行写操作的时候,JVM会向处理器发送一条Lock前缀的指令,会把这个变量所在缓存行的数据写回到系统内存。

b) 在多处理器的情况下,保证各个处理器缓存一致性的特点,就会实现缓存一致性协议。

Synchronized:可重入锁、互斥性、可见性。

Volatile 可以做到原子性、可见性;不能做到复合操作的原子性。

你可能感兴趣的:(java,面试)