java重新执行_(转载)java线程 - 线程唤醒后并被执行时,是在上次阻塞的代码行重新往下执行,而不是从头开始执行...
今天重新把昨晚的線程同步面試題做一遍時,發(fā)現(xiàn)實際情況運行下來時,線程一直不同步。后來經(jīng)過不斷測試,發(fā)現(xiàn)自己的一個誤區(qū)。
之前一直以為,線程如果被喚醒后再次執(zhí)行時,會從頭開始運行這個線程,也就是重新運行Runnable中的run()方法;
而實際情況是,被喚醒并且被執(zhí)行的線程是從上次阻塞的位置從下開始運行,也就是從wait()方法后開始執(zhí)行。
所以判斷是否進(jìn)入某一線程的條件 是用while判斷,而不是用If判斷判斷。
下面舉例說明:
如果三個線程同步工作,第一個線程打印1,2,3,4,5 ? ,然后第二個線程打印1,2,3,4,5 ?,接著第三個線程也打印 1,2,3,4,5,重復(fù)100次。
public class Thread_test {
static final manage m = new manage();
public static void main(String[] args) {
//線程一
new Thread(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
for(int i=0;i<50;i++){
m.threadPrint(i,0);
}
}
}).start();
//線程二
new Thread(new Runnable(){
public void run(){
for(int i=0;i<50;i++){
m.threadPrint(i,1);
}
}
}).start();
//線程三
new Thread(new Runnable(){
public void run(){
for(int i=0;i<50;i++){
m.threadPrint(i,2);
}
}
}).start();
}
}
//控制線程執(zhí)行的順序
class manage{
//權(quán)限,0代表1號線程執(zhí)行,1代表二號線程執(zhí)行,2代表三號線程執(zhí)行
private int isA = 0;
public synchronized void threadPrint(int i,int n){
/*該處應(yīng)用while來判斷是否輪到該線程執(zhí)行,假如用If判斷的話,如果該線程阻塞后再次被喚醒執(zhí)行時(其他線程調(diào)用this.notifyAll()),
他會從this.wait()后面的代碼開始執(zhí)行,即時沒輪到該線程執(zhí)行*/
while(this.isA != n){
try {
this.wait();
} catch (Exception e) {
// TODO: handle exception
}
}
for(int j=0;j<5;j++){
System.out.println(Thread.currentThread().getName()+":"+(j+1)+" loop in "+(i+1));
}
this.isA = (this.isA+1)%3;//將權(quán)限傳遞給后一個進(jìn)程62 this.notifyAll();
}
}
與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的java重新执行_(转载)java线程 - 线程唤醒后并被执行时,是在上次阻塞的代码行重新往下执行,而不是从头开始执行...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java 参数 string_关于Jav
- 下一篇: java 事件驱动 netty_Nett