可见性:是指线程之间的可见性,一个线程修改的状态对另一个线程是可见的。
指令重排序:是指CPU采用了允许将多条指令不按程序规定的顺序分开发送给各相应电路单元处理
volatile 原理:
- volatile 修饰的属性在修改后会直接将结果写回到主内存中
- volatile 防止指令重排,cpu为了提高性能,在编译代码时会将一些相同的操作放到一起执行,而volatile就会阻止这个操作
- 对非 volatile 变量进行读写的时候,每个线程先从内存拷贝变量到CPU缓存中。如果计算机有多个CPU,每个线程可能在不同的CPU上被处理,这意味着每个线程可以拷贝到不同的 CPU cache 中。
- volatile 的读性能消耗与普通变量几乎相同,但是写操作稍慢,因为它需要在本地代码中插入许多内存屏障指令来保证处理器不发生乱序执行。
- 在访问volatile变量时不会执行加锁操作,因此也就不会使执行线程阻塞,因此volatile变量是一种比sychronized关键字更轻量级的同步机制。