作者:gnuhpc
出處:http://www.cnblogs.com/gnuhpc/
當多個線程使用同一個變數時,每個線程都在其本地緩衝中有一個這個變數的拷貝,對這個變數的改變實際上是對這個複製品進行改變。而另一個線程在使用這個變數時還可能一無所知。為了避免這個問題,使用volatile這個關鍵字對便變數進行修飾,在對變數進行改變時直接作用於主記憶體。
package javabeat.samples;
class ExampleThread extends Thread {
private volatile int testValue;
public ExampleThread(String str){
super(str);
}
public void run() {
for (int i = 0; i < 3; i++) {
try {
System.out.println(getName() + " : "+i);
if (getName().equals("Thread 1 "))
{
testValue = 10;
}
if (getName().equals("Thread 2 "))
{
System.out.println( "Test Value : " + testValue);
}
Thread.sleep(1000);
} catch (InterruptedException exception) {
exception.printStackTrace();
}
}
}
}
public class VolatileExample {
public static void main(String args[]) {
new ExampleThread("Thread 1 ").start();
new ExampleThread("Thread 2 ").start();
}
}
作者:gnuhpc
出處:http://www.cnblogs.com/gnuhpc/