Java sleep方法及中斷方式、yield方法代碼實(shí)例
一、多線程的sleep方法
1.Thread.sleep(毫秒)
2.sleep方法是一個靜態(tài)方法
3.該方法的作用:阻塞當(dāng)前線程,騰出CPU,讓給其他線程
4.sleep的異常注意事項(xiàng),以及中斷休眠的一種方式及其注意點(diǎn)
package com.bjpowernode.java_learning; public class D106_1_ { public static void main(String[] args) throws InterruptedException{ Processer106 p1 = new Processer106(); p1.start(); //需求:子線程啟動后0.5s之后打斷它的休眠 Thread.sleep(500); p1.interrupt(); //這樣就會是子線程打斷休眠 //這個底層的實(shí)現(xiàn)方法是一個調(diào)用中斷異常的方式,因此,這個休眠之后的操作就不會執(zhí)行了 //在這個代碼中就會直接進(jìn)行下一次循環(huán) for (int i=0;i<5;i++) { System.out.println(Thread.currentThread().getName()+"---->"+i); //下面這個語句也可以使用對象.sleep();因?yàn)閟leep方法是一個靜態(tài)方法。 //即p1.sleep(200);這個main線程也會休眠200ms Thread.sleep(200); } } } class Processer106 extends Thread{ //Thread中的run方法不拋出異常,因此重寫run方法,在run方法的聲明位置不能使用throws //所以run方法中只能使用try...catch..... public void run() { for (int i=0;i<5;i++) { System.out.println(Thread.currentThread().getName()+"--->"+i); try { Thread.sleep(1000); //當(dāng)前線程阻塞1s System.out.println(i); } catch(InterruptedException e) { e.printStackTrace(); } } } //m1方法是可以使用throws的 }
二、如何正確的停止一個線程(不使用interrupt方法)
使用一個flag就可以達(dá)到我們的目的
packagepackage com.bjpowernode.java_learning; public class D106_2_InterruptSleep { public static void main(String[] args) throws Exception{ Processer106_2 p = new Processer106_2(); Thread t = new Thread(p); t.setName("t"); t.start(); //5s之后終止 Thread.sleep(5000); p.run1 = false; //這種非異常的方法更好,因?yàn)椴粫伋霎惓!? } } class Processer106_2 implements Runnable{ Boolean run1 = true; public void run() { for (int i=0;i<10;i++) { if(run1) { try { Thread.sleep(1000); } catch(InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+"-->"+i); } else { return; } } } }
三、Thread.yield
1.該方法是一個靜態(tài)方法
2.作用:給同一個優(yōu)先級的線程讓位,但是讓位時(shí)間不固定
3.和sleep方法相同,就是yield時(shí)間不固定
package com.bjpowernode.java_learning; public class D106_3_ThreadYield { public static void main(String[] args) throws InterruptedException { Processer106_3 p = new Processer106_3(); Thread t = new Thread(p); t.setName("t"); t.start(); //在主線程中 for (int i=0;i<1000;i++) { System.out.println(Thread.currentThread().getName()+"-->"+i); } } } class Processer106_3 implements Runnable{ public void run() { for (int i=0;i<1000;i++) { System.out.println(Thread.currentThread().getName()+"-->"+i); if(i%20 == 0) { Thread.yield(); } } } }
四、源碼:
D106_1_SleepMehthodAnalysis.java
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java中的HashSet詳解和使用示例_動力節(jié)點(diǎn)Java學(xué)院整理
HashSet 是一個沒有重復(fù)元素的集合。接下來通過實(shí)例代碼給大家介紹java中的hashset相關(guān)知識,感興趣的朋友一起看看吧2017-05-052022年最新java?8?(?jdk1.8u321)安裝圖文教程
這篇文章主要介紹了2022年最新java?8?(?jdk1.8u321)安裝圖文教程,截止2022年1月,官方出的jdk1.8目前已更新到8u321的版本,本文通過圖文并茂的形式給大家介紹安裝過程,需要的朋友可以參考下2022-08-08Java中的線程池ThreadPoolExecutor細(xì)致講解
這篇文章主要介紹了Java中的線程池ThreadPoolExecutor細(xì)致講解,線程池是一種基于池化思想管理線程的工具,經(jīng)常出現(xiàn)在多線程服務(wù)器中,如MySQL,線程過多會帶來額外的開銷,其中包括創(chuàng)建銷毀線程的開銷、調(diào)度線程的開銷等等,需要的朋友可以參考下2023-11-11spring-data-jpa中findOne與getOne的區(qū)別說明
這篇文章主要介紹了spring-data-jpa中findOne與getOne的區(qū)別說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11SpringSecurity怎樣使用注解控制權(quán)限
這篇文章主要介紹了SpringSecurity怎樣使用注解控制權(quán)限的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06