Java sleep方法及中斷方式、yield方法代碼實(shí)例
一、多線程的sleep方法
1.Thread.sleep(毫秒)
2.sleep方法是一個(gè)靜態(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();
//需求:子線程啟動(dòng)后0.5s之后打斷它的休眠
Thread.sleep(500);
p1.interrupt();
//這樣就會(huì)是子線程打斷休眠
//這個(gè)底層的實(shí)現(xiàn)方法是一個(gè)調(diào)用中斷異常的方式,因此,這個(gè)休眠之后的操作就不會(huì)執(zhí)行了
//在這個(gè)代碼中就會(huì)直接進(jìn)行下一次循環(huán)
for (int i=0;i<5;i++) {
System.out.println(Thread.currentThread().getName()+"---->"+i);
//下面這個(gè)語句也可以使用對象.sleep();因?yàn)閟leep方法是一個(gè)靜態(tài)方法。
//即p1.sleep(200);這個(gè)main線程也會(huì)休眠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的
}

二、如何正確的停止一個(gè)線程(不使用interrupt方法)
使用一個(gè)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)椴粫?huì)拋出異常。
}
}
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.該方法是一個(gè)靜態(tài)方法
2.作用:給同一個(gè)優(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詳解和使用示例_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
HashSet 是一個(gè)沒有重復(fù)元素的集合。接下來通過實(shí)例代碼給大家介紹java中的hashset相關(guān)知識(shí),感興趣的朋友一起看看吧2017-05-05
2022年最新java?8?(?jdk1.8u321)安裝圖文教程
這篇文章主要介紹了2022年最新java?8?(?jdk1.8u321)安裝圖文教程,截止2022年1月,官方出的jdk1.8目前已更新到8u321的版本,本文通過圖文并茂的形式給大家介紹安裝過程,需要的朋友可以參考下2022-08-08
Java中的線程池ThreadPoolExecutor細(xì)致講解
這篇文章主要介紹了Java中的線程池ThreadPoolExecutor細(xì)致講解,線程池是一種基于池化思想管理線程的工具,經(jīng)常出現(xiàn)在多線程服務(wù)器中,如MySQL,線程過多會(huì)帶來額外的開銷,其中包括創(chuàng)建銷毀線程的開銷、調(diào)度線程的開銷等等,需要的朋友可以參考下2023-11-11
spring-data-jpa中findOne與getOne的區(qū)別說明
這篇文章主要介紹了spring-data-jpa中findOne與getOne的區(qū)別說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11
SpringSecurity怎樣使用注解控制權(quán)限
這篇文章主要介紹了SpringSecurity怎樣使用注解控制權(quán)限的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06

