是java虚拟机提供的轻量级的同步机制(乞丐版的synchronized)
具备三个性质:保证可见性,不保证原子性,禁止指令重排
前置知识: java内存模型 (Java Memory Model) JMM_Pr Young的博客-CSDN博客
JMM这组规范关于同步的规定:
1.线程解锁前,必须把共享变量的值刷新回主内存
2.线程加锁前,必须读取主内存的最新值到自己的工作内存
3.加锁和解锁是同一把锁
1.保证可见性:当一个线程修改了某个共享变量的值时,其他线程是否能够立即知道这个修改。
volatile int number=0;
这样就可以保证,一个线程更改了共享变量number的值,其他线程也能立即知道这个修改
2.不保证原子性:
原子性:某个线程正在做某个具体业务的时候,不见不可以被打扰
volatile int number=0;
同样用volatile修饰共享变量,然后用20个线程都对这个共享变量进行加一操作,理论上讲,最后number的值应该是20,但实际上最后答案并不是20,这说明valatile不保证原子性
3.禁止指令重排
指令重排是指在程序执行过程中, 为了性能考虑, 编译器和CPU可能会对指令重新排序
在单线程环境中, 程序是按序依次执行的
在多线程环境中, 程序的执行可能因为指令重排而出现乱序