Volatile关键字--最轻量级的同步机制1.保证了不同线程对这个变量进行操作时的可见性,即一个线程修改了某个变量的值,这新值对其他线程来说是立即可见的。(实现可见性)
例如:如果一个oldvalue -->修改为newvalue ,这时的newvalue可以被其他的线程看到。
2.volatile不是线程安全的,只能保证对单次读/写的原子性。i++ 这种操作不能保证原子性。(不能保证原子性)最常使用场景:一写多读代码演示Volatile的可见性
public class VolatileCase { //未加volatile关键字 private static boolean ready = false; private static int number = 0; private static class ThreadInfo extends Thread{ @Override public void run() { System.out.println("Thread start"); while (!ready); System.out.println("number:"+number+"----ready:"+ready+"Thread end"); } } public static void main(String[] args) throws InterruptedException { new ThreadInfo().start(); Thread.sleep(100); ready = true; number = 123; Thread.sleep(100); System.out.println("main end"); } }
未加Volatile关键字运行结果:
加上Volatile关键字后:
//加volatile关键字 private volatile static boolean ready = false;
加上Volatile关键字运行结果:
综上:
证实Volatile的可见性:当一个线程修改一个Volatile修饰的变量时,其他线程可以实时看到。
代码演示Volatile的非原子性:
public class VolatileCase { //Volatile关键字 private volatile int count = 0; public int getCount() { return count; } public void setCount(int count) { this.count = count; } public void inCount(){ count++; } private static class ThreadInfo extends Thread{ private VolatileCase vc; public ThreadInfo(VolatileCase vc){ this.vc = vc; } @Override public void run() { for (int i = 0; i < 10000; i++) { vc.inCount(); } } } public static void main(String[] args) throws InterruptedException { VolatileCase vc = new VolatileCase(); ThreadInfo threadInfo1 = new ThreadInfo(vc); ThreadInfo threadInfo2 = new ThreadInfo(vc); threadInfo1.start(); threadInfo2.start(); Thread.sleep(100); System.out.println("main end:"+vc.getCount()); } }
第一次运行结果:
第二次运行结果:
正确的运行结果应该是20000的,但是每次结果都少于20000,证实Volatile的非原子性和非线程安全。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。