您好,登錄后才能下訂單哦!
Java中的內(nèi)核線程是什么?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
Java主要應(yīng)用于:1. web開發(fā);2. Android開發(fā);3. 客戶端開發(fā);4. 網(wǎng)頁開發(fā);5. 企業(yè)級應(yīng)用開發(fā);6. Java大數(shù)據(jù)開發(fā);7.游戲開發(fā)等。
內(nèi)核線程是直接由操作系統(tǒng)內(nèi)核控制的,內(nèi)核通過調(diào)度器來完成內(nèi)核線程的調(diào)度并負(fù)責(zé)將其映射到處理器上執(zhí)行。內(nèi)核態(tài)下的線程執(zhí)行速度理論上是最高的,但是用戶不會直接操作內(nèi)核線程,而是通過內(nèi)核線程的接口——輕量級進(jìn)程來間接的使用內(nèi)核線程。這種輕量級進(jìn)程就是所謂的線程。
由于內(nèi)核線程的支持,每一個線程都是一個獨(dú)立的單元,因此就算某一個線程掛掉了,也不會導(dǎo)致整個進(jìn)程掛掉。
這種實(shí)現(xiàn)方式也存在局限性。由于是基于內(nèi)核線程實(shí)現(xiàn)的,所以當(dāng)涉及到線程的操作時(創(chuàng)建、運(yùn)行、切換等)就涉及到系統(tǒng)調(diào)度,而系統(tǒng)調(diào)度則會導(dǎo)致用戶態(tài)和內(nèi)核態(tài)之間的來回切換,代價是比較昂貴的。
知識點(diǎn)擴(kuò)展:
線程的實(shí)現(xiàn)
線程是比進(jìn)程更輕量級的調(diào)度執(zhí)行單位,在linux里面,線程和進(jìn)程沒有什么區(qū)別,唯一的就是在地址空間,線程的切換虛擬內(nèi)存空間依然是相同的,但是進(jìn)程切換是不同的。
目前主流的操作系統(tǒng)都提供的線程實(shí)現(xiàn),java則提供的線程實(shí)現(xiàn)方法都是native的,因?yàn)椴煌挠布筒僮飨到y(tǒng)提供線程調(diào)度方式并不盡相同,所以java沒用采用和平臺無關(guān)的統(tǒng)一手段來實(shí)現(xiàn)。
用戶線程實(shí)現(xiàn)
用戶線程指不需要內(nèi)核支持而在用戶程序中實(shí)現(xiàn)的線程,其不依賴于操作系統(tǒng)核心,應(yīng)用進(jìn)程利用線程庫提供創(chuàng)建、同步、調(diào)度和管理線程的函數(shù)來控制用戶線程。
不需要用戶態(tài)/核心態(tài)切換,速度快,操作系統(tǒng)內(nèi)核不知道多線程的存在,因此一個線程阻塞將使得整個進(jìn)程(包括它的所有線程)阻塞。使用用戶線程實(shí)現(xiàn)的程序一般都比較復(fù)雜,java曾經(jīng)用過,不過最后還是放棄了。
優(yōu)點(diǎn):
切換由用戶態(tài)程序自己控制內(nèi)核切換,不需要內(nèi)核干涉,少了進(jìn)出內(nèi)核態(tài)的消耗。
缺點(diǎn):
多核處理器很難講線程映射到其他處理器上,單線程阻塞會造成該進(jìn)程阻塞。
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。