因為線程的執(zhí)行本身就是不確定的,加了synchronized關鍵字只能確?;コ庠L問這段代碼以及變量的可見性,并不能保證程序的執(zhí)行順序,也就是read和write方法的執(zhí)行順序。
2015-04-07
italycappuccino:因為線程的執(zhí)行是不能確定順序的,有可能是讀操作先執(zhí)行,然后才是寫操作執(zhí)行,所以會出現結果是0。
視頻最后也說了,加上一個sleep(1000);這樣就能保證寫操作先于讀操作執(zhí)行,就不會出現0了。
視頻最后也說了,加上一個sleep(1000);這樣就能保證寫操作先于讀操作執(zhí)行,就不會出現0了。
2015-04-05
@italycappuccino
出現0是因為讀線程先得到了執(zhí)行,讀線程執(zhí)行完,寫線程才執(zhí)行,這個我里面也有講到,你稍微注意下,在“synchronized實現可見性(下)”的第03:30之后!另外,慕課網這點估計剪切的估計太快了,有點不太容易注意到。你可以在寫線程和讀線程之間加個休眠操作,讓寫線程執(zhí)行完,讀線程再執(zhí)行,也可以使用wait和notify來控制線程執(zhí)行的順序!
出現0是因為讀線程先得到了執(zhí)行,讀線程執(zhí)行完,寫線程才執(zhí)行,這個我里面也有講到,你稍微注意下,在“synchronized實現可見性(下)”的第03:30之后!另外,慕課網這點估計剪切的估計太快了,有點不太容易注意到。你可以在寫線程和讀線程之間加個休眠操作,讓寫線程執(zhí)行完,讀線程再執(zhí)行,也可以使用wait和notify來控制線程執(zhí)行的順序!
2015-04-05
已采納回答 / MartonZhang
?出現0是因為讀線程先得到了執(zhí)行,讀線程執(zhí)行完,寫線程才執(zhí)行,這個我里面也有講到,你稍微注意下,在“synchronized實現可見性(下)”的第03:30之后!另外,慕課網這點估計剪切的估計太快了,有點不太容易注意到,可以在寫線程和讀線程之間加個休眠操作,讓寫線程執(zhí)行完,讀線程在執(zhí)行,也可以使用wait和notify來控制線程執(zhí)行的順序!
2015-04-05
public static void main(String[] args) {
for (int i = 0; i < 5000; i++) {
SynchronizedDemo2 demo = new SynchronizedDemo2();
demo.new ReadWriteThread(true).start();
demo.new ReadWriteThread(false).start();
}
}
for (int i = 0; i < 5000; i++) {
SynchronizedDemo2 demo = new SynchronizedDemo2();
demo.new ReadWriteThread(true).start();
demo.new ReadWriteThread(false).start();
}
}
2015-04-05
以下是部分代碼,加了synchronized關鍵字,結果中依然有0出現,費解。。。環(huán)境:mac,jdk1.8.0_05
public synchronized void write() {
ready = true;
number = 2;
}
public synchronized void read() {
if (ready) {
result = number * 3;
}
System.out.println("result=" + result);
}
public synchronized void write() {
ready = true;
number = 2;
}
public synchronized void read() {
if (ready) {
result = number * 3;
}
System.out.println("result=" + result);
}
2015-04-05