Java多線程狀態(tài)及方法實例解析
更新時間:2020年02月11日 14:52:25 作者:戈德里克山谷
這篇文章主要介紹了Java多線程狀態(tài)及方法實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
這篇文章主要介紹了Java多線程狀態(tài)及方法實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
首先介紹線程的五種狀態(tài):
新生態(tài):New Thread()
就緒態(tài):準備搶CPU時間片
運行態(tài):搶到了CPU時間片
阻塞態(tài):放棄已經(jīng)搶到的CPU時間片,且暫時不參與爭搶
死亡態(tài):Run運行完了之后

接下來介紹三種方法:線程的阻塞,線程的優(yōu)先級設置,線程的禮讓
public class MutliThreadDemo4 {
public static void main(String[] args) {
threadBlock();
//threadPriority();
//threadYield();
}
/**
* 線程的阻塞
*/
private static void threadBlock() {
//創(chuàng)建Runnable接口實現(xiàn)類的對象
Runnable r = () -> {
for(int i = 0; i < 10; i++) {
System.out.println(Thread.currentThread().getName() + ":" + i);
//線程休眠(由運行狀態(tài)到阻塞狀態(tài),時間過了回到就緒態(tài),重新爭搶),直觀上表現(xiàn)為停頓打印
try {
Thread.sleep(1000);
}catch(InterruptedException e){
e.printStackTrace();
}
}
};
//實例化
new Thread(r, "甲").start();
}
/**
* 線程的優(yōu)先級
*/
private static void threadPriority() {
Runnable r = () -> {
for(int i = 0; i < 10; i++) {
System.out.println(Thread.currentThread().getName() + ":" + i);
}
};
Thread t1 = new Thread(r, "甲");
Thread t2 = new Thread(r, "乙");
//設置優(yōu)先級,必須在開始執(zhí)行(start)之前
//設置線程的優(yōu)先級,只是修改這個線程可以去搶到CPU時間片的概率。
//并不是優(yōu)先級高的線程一定能搶到CPU時間片
//優(yōu)先級的設置,是一個整數(shù)(0,10]的整數(shù),默認是5
t1.setPriority(10);
t2.setPriority(1);
t1.start();
t2.start();
}
/**
* 線程的禮讓
*/
private static void threadYield() {
//線程釋放自己的CPU資源,由運行狀態(tài),回到就緒狀態(tài)
//匿名內(nèi)部類
Runnable r = new Runnable() {
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println(Thread.currentThread().getName() + ":" + i);
if (i == 3) {
Thread.yield();
}
}
}
};
Thread thread1 = new Thread(r, "thread-1");
Thread thread2 = new Thread(r, "thread-2");
thread1.start();
thread2.start();
}
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Java ArrayList與LinkedList使用方法詳解
Java中容器對象主要用來存儲其他對象,根據(jù)實現(xiàn)原理不同,主要有3類常用的容器對象:ArrayList使用數(shù)組結構存儲容器中的元素、LinkedList使用鏈表結構存儲容器中的元素2022-11-11
SpringBoot如何統(tǒng)一清理數(shù)據(jù)
這篇文章主要介紹了SpringBoot如何統(tǒng)一清理數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01

