因为线程的执行本身就是不确定的,加了synchronized关键字只能确保互斥访问这段代码以及变量的可见性,并不能保证程序的执行顺序,也就是read和write方法的执行顺序。
2015-04-07
italycappuccino:因为线程的执行是不能确定顺序的,有可能是读操作先执行,然后才是写操作执行,所以会出现结果是0。
视频最后也说了,加上一个sleep(1000);这样就能保证写操作先于读操作执行,就不会出现0了。
视频最后也说了,加上一个sleep(1000);这样就能保证写操作先于读操作执行,就不会出现0了。
2015-04-05
@italycappuccino
出现0是因为读线程先得到了执行,读线程执行完,写线程才执行,这个我里面也有讲到,你稍微注意下,在“synchronized实现可见性(下)”的第03:30之后!另外,慕课网这点估计剪切的估计太快了,有点不太容易注意到。你可以在写线程和读线程之间加个休眠操作,让写线程执行完,读线程再执行,也可以使用wait和notify来控制线程执行的顺序!
出现0是因为读线程先得到了执行,读线程执行完,写线程才执行,这个我里面也有讲到,你稍微注意下,在“synchronized实现可见性(下)”的第03:30之后!另外,慕课网这点估计剪切的估计太快了,有点不太容易注意到。你可以在写线程和读线程之间加个休眠操作,让写线程执行完,读线程再执行,也可以使用wait和notify来控制线程执行的顺序!
2015-04-05
已采纳回答 / MartonZhang
出现0是因为读线程先得到了执行,读线程执行完,写线程才执行,这个我里面也有讲到,你稍微注意下,在“synchronized实现可见性(下)”的第03:30之后!另外,慕课网这点估计剪切的估计太快了,有点不太容易注意到,可以在写线程和读线程之间加个休眠操作,让写线程执行完,读线程在执行,也可以使用wait和notify来控制线程执行的顺序!
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出现,费解。。。环境: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