Thread.sleep(long millis)和Thread.sleep(long millis, int nanos)靜態方法強制當前正在執行的線程休眠(暫停執行),以「減慢線程」。spa
當線程睡眠時,它睡在某個地方,在甦醒以前不會返回到可運行狀態。線程
當睡眠時間到期,則返回到可運行狀態。orm
線程睡眠的緣由:線程執行太快,或者須要強制進入下一輪,由於Java規範不保證合理的輪換。字符串
睡眠的實現:調用靜態方法。get
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}io
睡眠的位置:爲了讓其餘線程有機會執行,能夠將Thread.sleep()的調用放線程run()以內。這樣才能保證該線程執行過程當中會睡眠。class
public class TestSleep {
public static void main(String[] args) {
MyThread2 t1 = new MyThread2("TestSleep");
t1.start();
for(int i=0 ; i <10; i++)
System.out.println("I am Main Thread");
}
}
class MyThread2 extends Thread {
MyThread2(String s) {
super(s);
}
public void run() {
for(int i = 1; i <= 10; i++) {
System.out.println("I am "+getName());
try {
sleep(1000); //暫停,每一秒輸出一次
}catch (InterruptedException e) {
return;
}
}
}
}方法
注意:static
一、線程睡眠是幫助全部線程得到運行機會的最好方法。時間
二、線程睡眠到期自動甦醒,並返回到可運行狀態,不是運行狀態。sleep()中指定的時間是線程不會運行的最短期。所以,sleep()方法不能保證該線程睡眠到期後就開始執行。
三、sleep()是靜態方法,只能控制當前正在運行的線程。
實例二:一個計數器,計數到100,在每一個數字之間暫停1秒,每隔10個數字輸出一個字符串
public class MyThread extends Thread {
public void run() {
for (int i = 0; i < 100; i++) {
if ((i) % 10 == 0) {
System.out.println("-------" + i);
}
System.out.print(i);
try {
Thread.sleep(1000);
System.out.print(" 線程睡眠1秒!\n");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
public static void main(String[] args) { new MyThread().start(); }}