开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第11天,点击查看活动详情
synchronized
synchronized,即对象锁,它采用互斥的方式让同一 时刻至多只有一个线程能持有对象锁,其它线程再想获取这个对象锁时就会阻塞住(blocked)。这样就能保证拥有锁的线程可以安全的执行临界区内的代码,不用担心线程上下文切换。
volatile
volatile是Java中的关键字,用来修饰会被不同线程访问和修改的变量。 volatile关键字的作用主要有如下两个:
1.线程的可见性:当一个线程修改一个共享变量时,另外一个线程能读到这个修改的值。
2.顺序一致性:禁止指令重排序。
JMM Java Memory Model (java内存模型),在并发过程中如何处理可见性、原子性、有序性的问题:使用多线程Runnable/ Thread。
并发编程中的两个关键问题
- 线程之间如何通信:
-
wait()
-
notify()
-
notifyall()
a,共享内存 – 隐式通信
b,消息传递 – 显式通信
2. 线程之间如何同步 在共享内存的并发模型中,同步是显式做的;synchronized 在消息传递的并发模型中,由于消息的发送必须在消息的接收之前,所以同步是隐式
区别总结
对于声明了Volatile的变量进行写操作的时候,JVM会向处理器发送一条Lock前缀的指令,会把这个变量所在缓存行的数据写回到系统内存。
在多处理器的情况下,保证各个处理器缓存一致性的特点,就会实现缓存一致性协议。
Synchronized:可重入锁、互斥性、可见性。
Volatile 可以做到原子性、可见性;不能做到复合操作的原子性。