一猪半、功能介紹
讓當前線程( 調用sleep()方法的線程 )休息一會滞造,即是讓當前線程由運行狀態(tài)進入到阻塞狀態(tài)讳嘱,進而使其他線程有機會繼續(xù)執(zhí)行任務。雖然使線程休眠虎敦,但是并不釋放對象鎖游岳,所以說如果在同步塊中使用sleep(),其他線程仍然無法獲得執(zhí)行權限其徙。
注意:sleep()方法定義在Thread類中胚迫,會調用sleep(millis)這個本地方法,拋出InterruptedException異常唾那,因此需要捕獲該異常
二访锻、代碼示例
public class SleepDemo {
public static void main(String[] args) {
MyRunnable1 r = new MyRunnable1();
Thread t1 = new Thread(r, "t1");
Thread t2 = new Thread(r, "t2");
t1.start();
t2.start();
}
}
class MyRunnable1 implements Runnable {
@Override
public void run() {
synchronized (this) {
try {
for (int i = 0; i < 5; i++) {
System.out.println(Thread.currentThread().getName() + "--" + i);
/**
* t1,t2引用同一個對象鎖,
* 線程在模2為0的時候會休眠10ms闹获,但是沒有釋放對象鎖期犬,所以其他線程還需繼續(xù)等待,并不會獲得cpu的執(zhí)行權
*/
if (i % 2 == 0) {
Thread.sleep(10);
}
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
程序輸出:
t1--0
t1--1
t1--2
t1--3
t1--4
t2--0
t2--1
t2--2
t2--3
t2--4
三避诽、結果說明
主線程中啟動兩個線程龟虎,這兩個線程共享同一個Runnable實例。run方法是加鎖方法沙庐,輸出小于5的數鲤妥,并在模2=0時休眠10ms。線程并沒有交替執(zhí)行拱雏,獲得鎖的線程執(zhí)行結束后棉安,另一個線程才能獲取對象鎖,進而執(zhí)行铸抑。
四垂券、總結
sleep()是靜態(tài)方法,可以直接調用
sleep()方法使線程由運行狀態(tài)轉化為休眠阻塞狀態(tài)
sleep()并不會釋放對象鎖