sleep() wait() yield() join()用法與區別


1.sleep()方法

在指定時間內讓當前正在執行的線程暫停執行,但不會釋放“鎖標志”。不推薦使用。

sleep()使當前線程進入阻塞狀態,在指定時間內不會執行。

2.wait()方法

在其他線程調用對象的notify或notifyAll方法前,導致當前線程等待。線程會釋放掉它所占有的“鎖標志”,從而使別的線程有機會搶占該鎖。

當前線程必須擁有當前對象鎖。如果當前線程不是此鎖的擁有者,會拋出IllegalMonitorStateException異常。

喚醒當前對象鎖的等待線程使用notify或notifyAll方法,也必須擁有相同的對象鎖,否則也會拋出IllegalMonitorStateException異常。

waite()和notify()必須在synchronized函數或synchronized block中進行調用。如果在non-synchronized函數或non-synchronized block中進行調用,雖然能編譯通過,但在運行時會發生IllegalMonitorStateException的異常。

3.yield方法

暫停當前正在執行的線程對象。

yield()只是使當前線程重新回到可執行狀態,所以執行yield()的線程有可能在進入到可執行狀態后馬上又被執行。

yield()只能使同優先級或更高優先級的線程有執行的機會。 

4.join方法

等待該線程終止。

等待調用join方法的線程結束,再繼續執行。如:t.join();//主要用於等待t線程運行結束,若無此句,main則會執行完畢,導致結果不可預測。

publicclass Test {
        publicstaticvoid main(String[] args) {
                Thread t1 = new MyThread1();
                t1.start();

                for (int i = 0; i < 20; i++) {
                        System.out.println("主線程第" + i +"次執行!");
                        if (i > 2)try {
                                //t1線程合並到主線程中,主線程停止執行過程,轉而執行t1線程,直到t1執行完畢后繼續。
                                t1.join();
                        } catch (InterruptedException e) {
                                e.printStackTrace();
                        }
                }
        }
}

class MyThread1 extends Thread {
        publicvoid run() {
                for (int i = 0; i < 10; i++) {
                        System.out.println("線程1" + i + "次執行!");
                }
        }
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM