Java使用sleep方法暫停線程Thread
為什么要用sleep,主要是為了暫停當(dāng)前線程,把cpu片段讓出給其他線程,減緩當(dāng)前線程的執(zhí)行。
方法的定義:
public static void sleep(long millis);
public static native void sleep(long millis) throws InterruptedException;
通過定義可以看出sleep方法是本地方法,通過系統(tǒng)調(diào)用暫停當(dāng)前線程,而不是java自己實現(xiàn)的。
sleep還有一個重載的方法:
public static void sleep(long millis, int nanos)
實現(xiàn)如下:
public static void sleep(long millis, int nanos) throws InterruptedException { if (millis < 0) { throw new IllegalArgumentException("timeout value is negative"); } if (nanos < 0 || nanos > 999999) { throw new IllegalArgumentException( "nanosecond timeout value out of range"); } if (nanos >= 500000 || (nanos != 0 && millis == 0)) { millis++; } sleep(millis); }
從表面現(xiàn)象上來看,這個方法支持納秒級別的暫定,但是內(nèi)部的實現(xiàn)最終還是毫秒級別的執(zhí)行,以500 000納秒作為分割,大于這個值時,線程在millis的基礎(chǔ)上多sleep 1毫秒,否則還是sleep millis毫秒,當(dāng)然如果millis為0時,會sleep 1毫秒。
寫個簡單的demo來看線程的執(zhí)行:
import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; public class ThreadTest implements Runnable{ public static void main(String[] args) throws InterruptedException { Thread test1 = new Thread(new ThreadTest()); Thread test2 = new Thread(new ThreadTest()); test1.start(); test2.start(); test1.sleep(5000); } @Override public void run() { for (int i = 0; i < 5; i++){ System.out.println(i); } } }
執(zhí)行結(jié)果:
0 1 2 3 4 0 1 2 3 4 //此處會暫停5秒 end
值得注意的是:
- 1. sleep是幫助其他線程獲得運行機會的最好方法,但是如果當(dāng)前線程獲取到的有鎖,sleep不會讓出鎖。
- 2. 線程睡眠到期自動蘇醒,并返回到可運行狀態(tài)(就緒),不是運行狀態(tài)。
- 3. 優(yōu)先線程的調(diào)用,現(xiàn)在蘇醒之后,并不會里面執(zhí)行,所以sleep()中指定的時間是線程不會運行的最短時間,sleep方法不能作為精確的時間控制。
- 3、sleep()是靜態(tài)方法,只能控制當(dāng)前正在運行的線程(示例就是這樣調(diào)用的,因為類對象可以調(diào)用類的靜態(tài)方法)。
到此這篇關(guān)于Java使用sleep方法暫停線程Thread的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python中scrapy框架的ltem和scrapy.Request詳解
這篇文章主要介紹了Python中scrapy框架的ltem和scrapy.Request詳解,Item是保存爬取數(shù)據(jù)的容器,它的使用方法和字典類似,不過,相比字典,Item提供了額外的保護機制,可以避免拼寫錯誤或者定義字段錯誤,需要的朋友可以參考下2023-09-09java課程設(shè)計做一個多人聊天室(socket+多線程)
這篇文章主要介紹了我的java課程設(shè)計一個多人聊天室(socket+多線程)本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08Java 多線程等待優(yōu)雅的實現(xiàn)方式之Phaser同步屏障
在JAVA 1.7引入了一個新的并發(fā)API:Phaser,一個可重用的同步barrier。在此前,JAVA已經(jīng)有CyclicBarrier、CountDownLatch這兩種同步barrier,但是Phaser更加靈活,而且側(cè)重于 重用2021-11-11