volatile理解

java内存模型(主内存<---->工作内存)
1.可见性
A线程将共享变量读进工作内存中,同时B线程也将共享变量读进工作内存中,在A线程对共享变量修改后,会立即刷新到主内存,此时B线程的工作内存中的共享变量就会被设置无效,需要从主内存中重新读取新值。

2.有序性:禁止JVM和处理器对volatile关键字修饰的变量进行指令重排序,但该变量前后的不禁止。底层原理通过“lock:”的前缀指令。

3.volatile不保证原子性
假设此时num的值为10,线程A将变量读进自己的工作内存中,此时发生了CPU切换,B也将num读进自己的工作内存,此时值也是10.B线程在自己的工作内存中对num的值进行修改,变成了11,但此时还没有刷新到主内存,因此A线程还不知道num的值已经发生了改变,对volatile变量修改后,其它线程会立即得知,前提也是要先刷新到主内存中,这时,其它线程才会将自己工作中的共享变量的值设为无效。因为没有刷新到主内存,因此A在10的基础上加一,因此最终虽然两个线程都进行了加一操作,但最终的结果只加了一次。

4.使用场景:多线程中的开关、状态标识

你可能感兴趣的:(java学习笔记)