在Java多线程并发中,Volatile和Synchronizedzed都扮演着重要的角色,Volatile是轻量级的Synchronized,它在多处理器开发中保证了共享变量的可见性。“可见性”是指当一个线程修改变量时,另一个线程也能读到修改后的值。
1:Volatile的定义和实现原理
Lock前缀指令会引发两件事:
1:当前处理器缓存行的数据写回系统内存
2:这个写回内存的操作会使得CPU里其他缓存了该内存地址的数据无效。
如果对申明了Volatile的变量进行写操作,JVM会向处理器发送一条Lock前缀的指令,将这个变量所在缓存行的数据写回系统内存。多处理器下,为保证各个处理器缓存是一致的,会实现缓存一致性协议,每个处理器通过嗅探在总线上传播的数据来检查自己缓存的值是否过期,如果发现缓存行对应的内存地址被修改,就会将当前处理器的缓存行设置为无效状态,当处理器对这个数据进行修改时,会重新从系统内存中将数据读到处理器缓存中。
2:Synchronized的定义和实现原理
Java 中的同步块用 synchronized 关键字标记。Java 中的同步块在某个对象上同步。在同一个对象上同步的所有同步块一次只能在其中执行一个线程。所有其他试图进入同步块的线程都被阻塞,直到同步块内的线程退出该块。
1、synchronized作用