Java線程的生命周期命名與獲取代碼實現(xiàn)
一、線程的生命周期
1.五種狀態(tài):新建狀態(tài)、就緒狀態(tài)、運行狀態(tài)、阻塞狀態(tài)、消亡狀態(tài)
2.就緒狀態(tài)的線程表示有權(quán)利去獲取CPU的時間片,CPU時間片是執(zhí)行權(quán),當(dāng)線程拿到CPU時間片之后就馬上執(zhí)行run方法,這個時候就代表進入了運行狀態(tài)
二、線程的調(diào)度與控制
通常我們的計算機只有一個CPU,CPU在某一個時刻只能執(zhí)行一條指令,線程只有得到CPU時間片,也就是使用權(quán),才可以執(zhí)行指令。在單CPU的機器上線程不是并行運行的,只有個在多個CPU上線程才可以并行運行。Java虛擬機要負(fù)責(zé)線程的調(diào)度,取得CPU的使用權(quán),目前有兩種調(diào)度模型:分時調(diào)度模型和搶占式調(diào)度模型,Java使用搶占式調(diào)度模型。
分時調(diào)度模型:所有線程輪流使用CPU的使用權(quán),平均分配每個線程占用CPU的時間片;
搶占式調(diào)度模型:優(yōu)先讓優(yōu)先級高的線程使用CPU,如果線程的優(yōu)先級相同,那么會隨機選擇一個,優(yōu)先級高的線程獲取CPU時間片相對多一些。
線程優(yōu)先級主要分為三種:MAX_PRIORITY(最高級);MIN_PRIORITY(最低級);NORM_PRIORITY(標(biāo)準(zhǔn))默認(rèn)
package com.bjpowernode.java_learning; import com.sun.imageio.plugins.tiff.TIFFT4Compressor; public class D104_1_MultiThreadDispatchAndControl { public static void main(String[] args) { //如何獲取當(dāng)前線程對象 Thread t = Thread.currentThread(); //t保存的內(nèi)存地址指向的是線程是“主線程對象” //獲取線程的名字 System.out.println(t.getName()); Thread t2 = new Thread(new Processor104_1()); t2.start(); Thread t3 = new Thread(new Processor104_1()); t3.start(); //可以給線程起名字 Thread t4 = new Thread(new Processor104_1()); t4.setName("t4"); t4.start(); } } class Processor104_1 implements Runnable{ public void run() { Thread t = Thread.currentThread(); System.out.println(t.getName()); } }
三、源碼
D104_1_MultiThreadDispatchAndControl.java
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
在SpringBoot項目中如何實現(xiàn)線程池的動態(tài)監(jiān)控
Spring Boot因其簡便、高效的特點廣受開發(fā)者喜愛,在復(fù)雜的業(yè)務(wù)場景下,如何確保Spring Boot應(yīng)用的高性能和穩(wěn)定性成為了一個關(guān)鍵問題,其中,線程池的管理策略直接影響到系統(tǒng)的吞吐量和資源利用效率,本文將重點探討在Spring Boot項目中,如何實現(xiàn)線程池的動態(tài)監(jiān)控2023-10-10Springboot?定時任務(wù)分布式下冪等性解決方案
這篇文章主要介紹了Springboot定時任務(wù)分布式下冪等性如何解決,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07