1.sleep()方法
在指定時間內讓當前正在執行的線程暫停執行,但不放鎖!!!!
sleep()使當前線程進入阻塞狀態,在指定時間內不會執行。
sleep的時間到了之后,雖然不用搶鎖了,但還要和其他線程搶CPU時間片,也就是說,下面的代碼,每隔一秒打印一次當前時間,兩次打印的間隔有可能超過1秒,即打印的時間不連續。

1 import java.text.SimpleDateFormat; 2 import java.util.Date; 3 import java.util.Scanner; 4 //線程1:每sleep 1000毫秒 打印一次當前時間 5 //線程2:按回車可以打斷線程1的sleep狀態 6 public class Test { 7 public static void main(String[] args) { 8 Thread t = new Thread() { 9 @Override 10 public void run() { 11 for (int i = 0;i<=10000000;i++) { 12 SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss"); 13 String s = sdf.format(new Date()); 14 System.out.println(s); 15 try { 16 Thread.sleep(1000); 17 } catch (InterruptedException e) { 18 System.out.println("結束"); 19 break; 20 } 21 } 22 } 23 }; 24 t.start(); 25 Thread t2 = new Thread() { 26 @Override 27 public void run() { 28 System.out.println("按回車喚醒t"); 29 new Scanner(System.in).nextLine(); 30 t.interrupt(); 31 } 32 }; 33 t2.setDaemon(true); 34 t2.start(); 35 } 36 }
2.wait()方法
在其他線程調用對象的notify或notifyAll方法前,導致當前線程等待。會放鎖!!!!從而使別的線程有機會搶占該鎖。
當前線程必須擁有當前對象鎖。如果當前線程不是此鎖的擁有者,會拋出IllegalMonitorStateException異常。
喚醒當前對象鎖的等待線程使用notify或notifyAll方法,也必須擁有相同的對象鎖,否則也會拋出IllegalMonitorStateException異常。
wait()和notify()必須在synchronized函數或synchronized block中進行調用。如果不在,雖然能編譯通過,但在運行時會發生IllegalMonitorStateException的異常。
wait(時間),時間一到,不需要喚醒,可以自己重新搶鎖,繼續執行。

1 sychronized(a){ 2 a.wait(); 3 a.notify();//隨機喚醒 4 a.notifyAll();//全部喚醒 5 }
3.yield方法
暫停當前正在執行的線程對象。不放鎖!!!!
yield()只是使當前線程重新回到可執行狀態,所以執行yield()的線程有可能在進入到可執行狀態后,當場搶到CPU時間片,又被執行,甚至,無限連任!!!
yield()只能使同優先級或更高優先級的線程有執行的機會。機會我已經給讓你們了,能不能搶過我,那就看優先級和聽天由命了。
4.join方法
等待該線程終止。
等待調用join方法的線程結束,再繼續執行。如:t.join();//主要用於等待t線程運行結束,若無此句,main則會執行完畢,導致結果不可預測。