Java Volatile关键字同步机制详解

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的非原子性和非线程安全。

以上是 Java Volatile关键字同步机制详解 的全部内容, 来源链接: utcz.com/z/311982.html

回到顶部