国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Java領(lǐng)域中的線程機(jī)制-線程(一)

Java領(lǐng)域中的線程機(jī)制-線程(一)

來(lái)源:千鋒教育
發(fā)布人:qyf
時(shí)間: 2022-08-03 15:38:53 1659512333

1

  在早期的操作系統(tǒng)中,執(zhí)行任務(wù)被抽象為進(jìn)程(Process)。其中,進(jìn)程是操作系統(tǒng)運(yùn)行和調(diào)度的基本單元。

  隨著計(jì)算機(jī)技術(shù)的不斷發(fā)展,由于進(jìn)程開銷資源較大,以進(jìn)程為調(diào)度單位的方式逐漸產(chǎn)生弊端。因此,計(jì)算機(jī)先進(jìn)工作者(科學(xué)家)們?cè)谶M(jìn)程的基礎(chǔ)上,提出了線程(Thead)的概念。

  線程是進(jìn)程中的運(yùn)行單位,可以把線程看作輕量級(jí)的進(jìn)程。計(jì)算機(jī)CPU會(huì)按照某種策略為每一個(gè)線程分配一定的時(shí)間片去執(zhí)行。

  進(jìn)程是指程序的一次動(dòng)態(tài)執(zhí)行過(guò)程,計(jì)算機(jī)中正在執(zhí)行的程序就是進(jìn)程,每一個(gè)程序都對(duì)對(duì)應(yīng)著各自的一個(gè)進(jìn)程。

  一個(gè)進(jìn)程包含了從代碼加載完畢到執(zhí)行完成的一個(gè)完成過(guò)程,是操作系統(tǒng)中資源分配的最小單位。

  線程是比進(jìn)程更小的執(zhí)行單元,是計(jì)算機(jī)CPU調(diào)度和分配的基本單位。

  每一個(gè)進(jìn)程都會(huì)至少包含一個(gè)線程,而一個(gè)線程只屬于一個(gè)進(jìn)程。

  每一個(gè)進(jìn)程都有自己的資源,一個(gè)進(jìn)程內(nèi)的所有線程都共享這個(gè)進(jìn)程所包含的資源。

  每一個(gè)線程可以對(duì)所屬進(jìn)程的所有資源進(jìn)行調(diào)度和運(yùn)算,其中,線程可以是操作系統(tǒng)內(nèi)核來(lái)控制調(diào)度,也可以是由用戶程序來(lái)控制調(diào)度。

  基本定義

2

  現(xiàn)代計(jì)算機(jī),從組成部分上來(lái)看,大體可以分為硬件和軟件兩個(gè)部分。硬件是基礎(chǔ),而軟件是運(yùn)行在硬件之上的程序。

  其中,軟件可以分為操作系統(tǒng)和應(yīng)用程序:

  操作系統(tǒng)(Operation System):專注于對(duì)硬件的支持和交互管理并提供一個(gè)運(yùn)行環(huán)境給應(yīng)用程序使用

  應(yīng)用程序(Application Program):能實(shí)現(xiàn)若干功能且運(yùn)行在操作系統(tǒng)中的軟件

  由于線程可以由操作系統(tǒng)內(nèi)核和用戶程序來(lái)控制調(diào)度,因此按照操作系統(tǒng)和應(yīng)用程序兩個(gè)層次來(lái)分類。

  線程可以主要分為內(nèi)核線程和 用戶線程(應(yīng)用線程)兩類,其中:

  內(nèi)核線程(Kernel Thread):由操作系統(tǒng)內(nèi)核支持和管理的線程,內(nèi)核線程的創(chuàng)建,啟動(dòng),同步,銷毀,切換等均由操作系統(tǒng)完成。

  用戶(應(yīng)用線程,Applciation Thread)線程(User Thread) :用戶(應(yīng)用)線程的管理工作在用戶(應(yīng)用)空間完成,它完全建立在用戶(應(yīng)用)空間的線程庫(kù)上,由內(nèi)核支持但不由內(nèi)核管理,內(nèi)核也無(wú)法感知用戶線程的存在。用戶(應(yīng)用)線程的創(chuàng)建,啟動(dòng),同步,銷毀,切換等均在在用戶(應(yīng)用)空間完成,不用切換到內(nèi)核。

  從Java領(lǐng)域來(lái)看,Java語(yǔ)言編譯后的字節(jié)碼(Byte Code) 運(yùn)行在JVM (Java 虛擬機(jī))上,其中JVM其實(shí)是一個(gè)進(jìn)程,所以Java屬于應(yīng)用程序?qū)印?/p>

  我們都知道,Java的線程類為:java.lang.Thread,當(dāng)任務(wù)不能在當(dāng)前線程中執(zhí)行時(shí),我們就會(huì)去創(chuàng)建一個(gè)Thread對(duì)象。

  我們?cè)贘ava層通過(guò)new 關(guān)鍵字創(chuàng)建一個(gè)Thread對(duì)象,然后調(diào)用start()方法啟動(dòng)該線程,那么從線程的角度來(lái)看,主要可以分為:

  Java應(yīng)用程序?qū)泳€程(Java Application Thread ):主要是Java語(yǔ)言編程的程序創(chuàng)建的Thread線程對(duì)象,屬于用戶空間

  Java虛擬機(jī)層線程(Java JVM Thread ):主要是Java虛擬機(jī)中包含且支持和管理的線程,屬于用戶空間,

  操作系統(tǒng)層線程(OS Thread):根據(jù)操作系統(tǒng)的實(shí)際情況而定的抽象表示,主要是看操作系統(tǒng)和庫(kù)是否支持和管理的線程,一般Linux主要通過(guò)pthread庫(kù)來(lái)實(shí)現(xiàn),早期版本不支持。

  其中,在Hotspot JVM 中的 Java 線程與原生操作系統(tǒng)線程有直接的映射關(guān)系。當(dāng)線程本地存儲(chǔ)、緩沖區(qū)分配、同步對(duì)象、棧、程序計(jì)數(shù)器等準(zhǔn)備好以后,就會(huì)創(chuàng)建一個(gè)操作系統(tǒng)原生線程。

  Java 線程結(jié)束,原生線程隨之被回收。操作系統(tǒng)負(fù)責(zé)調(diào)度所有線程,并把它們分配到任何可用的 CPU 上。

  當(dāng)原生線程初始化完畢,就會(huì)調(diào)用 Java 線程的 run() 方法。當(dāng)線程結(jié)束時(shí),會(huì)釋放原生線程和 Java 線程的所有資源。

  一般在Hotspot JVM 后臺(tái)運(yùn)行的系統(tǒng)線程主要有下面幾方面:

  虛擬機(jī)線程(VM thread):這個(gè)線程等待 JVM 到達(dá)安全點(diǎn)操作出現(xiàn)。這些操作必須要在獨(dú)立的線程里執(zhí)行,因?yàn)楫?dāng)堆修改無(wú)法進(jìn)行時(shí),線程都需要 JVM 位于安全點(diǎn)。這些操作的類型有:stop-theworld

  垃圾回收、線程棧 dump、線程暫停、線程偏向鎖(biased locking)解除。

  周期性任務(wù)線程: 這線程負(fù)責(zé)定時(shí)器事件(也就是中斷),用來(lái)調(diào)度周期性操作的執(zhí)行。

  GC 線程: 這些線程支持 JVM 中不同的垃圾回收活動(dòng)。

  編譯器線程: 這些線程在運(yùn)行時(shí)將字節(jié)碼動(dòng)態(tài)編譯成本地平臺(tái)相關(guān)的機(jī)器碼。

  信號(hào)分發(fā)線程: 這個(gè)線程接收發(fā)送到 JVM 的信號(hào)并調(diào)用適當(dāng)?shù)?JVM 方法處理。

  由此可見,Java層到內(nèi)層層的線程創(chuàng)建的大致流程:java.lang.Thread(Java應(yīng)用程序?qū)?—>Java Thread(JVM 層)->OS Thread(操作系統(tǒng)層)->pthread(根據(jù)操作系統(tǒng)的情況而定)->內(nèi)核線程(Kernel Thread)。

  更多關(guān)于“java培訓(xùn)”的問(wèn)題,歡迎咨詢千鋒教育在線名師。千鋒教育多年辦學(xué),課程大綱緊跟企業(yè)需求,更科學(xué)更嚴(yán)謹(jǐn),每年培養(yǎng)泛IT人才近2萬(wàn)人。不論你是零基礎(chǔ)還是想提升,都可以找到適合的班型,千鋒教育隨時(shí)歡迎你來(lái)試聽。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
服務(wù)器為什么要用Linux?

服務(wù)器為什么要用Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,有其獨(dú)特的優(yōu)勢(shì)和特點(diǎn)。包括其...詳情>>

2023-10-14 12:34:11
ORM解決的主要問(wèn)題是什么?

ORM(對(duì)象關(guān)系映射)解決的主要問(wèn)題是將關(guān)系數(shù)據(jù)庫(kù)與面向?qū)ο缶幊讨g的映射困境。在傳統(tǒng)的關(guān)系數(shù)據(jù)庫(kù)中,數(shù)據(jù)以表格的形式存儲(chǔ),而在面向?qū)ο?..詳情>>

2023-10-14 12:26:19
Go為什么不支持三元運(yùn)算符?

Go為什么不支持三元運(yùn)算符Go語(yǔ)言是一種以簡(jiǎn)潔和有效性為目標(biāo)的編程語(yǔ)言,因此在設(shè)計(jì)過(guò)程中,Go的設(shè)計(jì)者刻意排除了一些他們認(rèn)為可能導(dǎo)致復(fù)雜性或...詳情>>

2023-10-14 12:12:36
IT通常說(shuō)的平臺(tái)是什么意思?

在信息技術(shù)(IT)領(lǐng)域,”平臺(tái)”這個(gè)詞有著廣泛的含義,它常常指代支持軟件應(yīng)用開發(fā)和運(yùn)行的基礎(chǔ)框架和環(huán)境。以下是對(duì)”平臺(tái)”這個(gè)概念的更深入...詳情>>

2023-10-14 11:55:36
什么是PowerPivot?

什么是PowerPivotPowerPivot,全稱”PowerPivot for Excel”,是Microsoft提供的一種數(shù)據(jù)分析工具,可以作為Excel的插件使用。通過(guò)PowerPivot,...詳情>>

2023-10-14 11:25:48