java線程

線程定義

線程(英語(yǔ):thread)是操作系統(tǒng)能夠進(jìn)行運(yùn)算調(diào)度的最小單位溜徙。它被包含在進(jìn)程之中湃缎,是進(jìn)程中的實(shí)際運(yùn)作單位。一條線程指的是進(jìn)程中一個(gè)單一順序的控制流蠢壹,一個(gè)進(jìn)程中可以并發(fā)多個(gè)線程嗓违,每條線程并行執(zhí)行不同的任務(wù)。在Unix System V及SunOS中也被稱為輕量進(jìn)程(lightweight processes)图贸,但輕量進(jìn)程更多指內(nèi)核線程(kernel thread)蹂季,而把用戶線程(user thread)稱為線程。

線程是獨(dú)立調(diào)度和分派的基本單位求妹。線程可以操作系統(tǒng)內(nèi)核調(diào)度的內(nèi)核線程,如Win32線程佳窑;由用戶進(jìn)程自行調(diào)度的用戶線程制恍,如Linux平臺(tái)的POSIX Thread;或者由內(nèi)核與用戶進(jìn)程神凑,如Windows 7的線程净神,進(jìn)行混合調(diào)度。

同一進(jìn)程中的多條線程將共享該進(jìn)程中的全部系統(tǒng)資源溉委,如虛擬地址空間鹃唯,文件描述符和信號(hào)處理等等。但同一進(jìn)程中的多個(gè)線程有各自的調(diào)用棧(call stack)瓣喊,自己的寄存器環(huán)境(register context)坡慌,自己的線程本地存儲(chǔ)(thread-local storage)。

一個(gè)進(jìn)程可以有很多線程藻三,每條線程并行執(zhí)行不同的任務(wù)洪橘。

線程實(shí)現(xiàn)

Java中的線程都是調(diào)用的原生系統(tǒng)的本地函數(shù)跪者,Java線程模型是基于操作系統(tǒng)原生線程模型實(shí)現(xiàn)的,實(shí)現(xiàn)線程有三種方式:內(nèi)核線程實(shí)現(xiàn)熄求、用戶線程實(shí)現(xiàn)渣玲、混合線程實(shí)現(xiàn)。

內(nèi)核線程實(shí)現(xiàn)

直接由操作系統(tǒng)內(nèi)核支持的線程弟晚,通過(guò)內(nèi)核來(lái)完成進(jìn)程切換忘衍。每個(gè)內(nèi)核線程就是一個(gè)內(nèi)核的分身,這樣操作系統(tǒng)就可以同時(shí)處理多件事情卿城,支持多線程的內(nèi)核被稱為多線程內(nèi)核枚钓。

程序一般不直接使用內(nèi)核線程,而是使用一種高級(jí)接口——輕量級(jí)進(jìn)程藻雪,輕量級(jí)進(jìn)程就是我們通常意義上的線程秘噪,可以獲得內(nèi)核線程的支持,與內(nèi)核線程構(gòu)成1:1的線程模型勉耀。

thread_1.jpg

由于得到內(nèi)核線程的支持指煎,每個(gè)輕量級(jí)進(jìn)程都成為一個(gè)獨(dú)立的調(diào)度單元,即時(shí)有一個(gè)輕量級(jí)進(jìn)程在系統(tǒng)調(diào)用中阻塞便斥,也不會(huì)影響整個(gè)進(jìn)程至壤,但也有其局限性:由于是基于內(nèi)核線程實(shí)現(xiàn)的,各種操作枢纠,如創(chuàng)建像街、銷毀及同步,都需要進(jìn)行系統(tǒng)調(diào)用晋渺。而系統(tǒng)調(diào)用代價(jià)較高镰绎,需要在內(nèi)核態(tài)和用戶態(tài)來(lái)回切換。

用戶線程實(shí)現(xiàn)

從廣義上說(shuō)木西,一個(gè)線程不是內(nèi)核線程畴栖,就是用戶線程,所以輕量級(jí)進(jìn)程也屬于用戶線程八千。狹義的用戶線程是指完全建立在用戶空間上的吗讶,系統(tǒng)內(nèi)核不能感知到其存在。

用戶線程的創(chuàng)建恋捆、同步照皆、銷毀和調(diào)度都是在用戶空間實(shí)現(xiàn)的,因此相對(duì)較快沸停,代價(jià)相對(duì)較低膜毁。這種用戶線程和進(jìn)程是N:1的線程模型。

thread_2.jpg

由于用戶線程沒(méi)有內(nèi)核的支持,線程的創(chuàng)建爽茴、切換和調(diào)度是需要自己實(shí)現(xiàn)的葬凳,而且由于操作系統(tǒng)只把CPU資源分配到進(jìn)程,那諸如“阻塞如何處理”室奏、“多處理器系統(tǒng)中如何將線程映射到其他處理器”這類問(wèn)題解決起來(lái)異常復(fù)雜火焰。

混合實(shí)現(xiàn)

這種實(shí)現(xiàn)模式將內(nèi)核線程與用戶線程一起使用,在這種方式下既存在用戶線程胧沫,也存在輕量級(jí)進(jìn)程昌简。用戶線程還是完全建立在用戶空間,因此用戶線程的創(chuàng)建绒怨、切換等操作依舊低廉纯赎。而操作系統(tǒng)提供的輕量級(jí)進(jìn)程則作為用戶線程和內(nèi)核線程的橋梁,這樣就可以使用內(nèi)核提供的線程調(diào)度及處理器映射南蹂。這種實(shí)現(xiàn)下犬金,用戶線程和輕量級(jí)進(jìn)程是M:N的模式。

thread_3.jpg

Java線程調(diào)度

線程調(diào)度分為協(xié)同式和搶占式六剥。

  • 協(xié)同式調(diào)度:線程的執(zhí)行時(shí)間由線程自己控制晚顷,這種的實(shí)現(xiàn)很簡(jiǎn)單,但是很可能造成很?chē)?yán)重的后果疗疟。
  • 搶占式調(diào)度:由操作系統(tǒng)分配線程執(zhí)行的時(shí)間该默,線程切換的決定權(quán)在操作系統(tǒng)。

有時(shí)候我們需要為某些線程多分配時(shí)間策彤,這時(shí)我們就需要用到線程優(yōu)先級(jí)的方法栓袖,Java提供了10種優(yōu)先級(jí)。Java優(yōu)先級(jí)是在操作系統(tǒng)的原生線程優(yōu)先級(jí)上實(shí)現(xiàn)的店诗,所以對(duì)于同一個(gè)優(yōu)先級(jí)裹刮,不同的操作系統(tǒng)可能有不同的表現(xiàn),也就是說(shuō) Java線程優(yōu)先級(jí)不是可靠的庞瘸。

Java線程狀態(tài)切換

Java線程模型定義了 6 種狀態(tài)捧弃,在任意一個(gè)時(shí)間點(diǎn),一個(gè)線程有且只有其中一個(gè)狀態(tài):

  • 新建(New):新建的Thread恕洲,尚未開(kāi)始塔橡。
  • 運(yùn)行(Runable):包含操作系統(tǒng)線程狀態(tài)中的Running梅割、Ready霜第,也就是處于正在執(zhí)行或正在等待CPU分配時(shí)間的狀態(tài)。
  • 無(wú)限期等待(Waiting):處于這種狀態(tài)的線程不會(huì)被分配CPU時(shí)間户辞,等待其他線程喚醒泌类。
  • 限期等待(Timed Waiting):處于這種狀態(tài)的線程不會(huì)被分配CPU時(shí)間,在一定時(shí)間后會(huì)由系統(tǒng)自動(dòng)喚醒。
  • 阻塞(Blocked):在等待獲得排他鎖刃榨。
  • 結(jié)束(Terminated):已終止的線程弹砚。
thread_4.jpg

線程安全

多線程訪問(wèn)同一代碼,不會(huì)產(chǎn)生不確定的結(jié)果枢希。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末桌吃,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子苞轿,更是在濱河造成了極大的恐慌茅诱,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件搬卒,死亡現(xiàn)場(chǎng)離奇詭異瑟俭,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)契邀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)摆寄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人坯门,你說(shuō)我怎么就攤上這事微饥。” “怎么了田盈?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵畜号,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我允瞧,道長(zhǎng)简软,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任述暂,我火速辦了婚禮痹升,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘畦韭。我一直安慰自己疼蛾,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布艺配。 她就那樣靜靜地躺著察郁,像睡著了一般。 火紅的嫁衣襯著肌膚如雪转唉。 梳的紋絲不亂的頭發(fā)上皮钠,一...
    開(kāi)封第一講書(shū)人閱讀 49,837評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音赠法,去河邊找鬼麦轰。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的款侵。 我是一名探鬼主播末荐,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼新锈!你這毒婦竟也來(lái)了甲脏?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤妹笆,失蹤者是張志新(化名)和其女友劉穎剃幌,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體晾浴,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡负乡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了脊凰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抖棘。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖狸涌,靈堂內(nèi)的尸體忽然破棺而出切省,到底是詐尸還是另有隱情,我是刑警寧澤帕胆,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布朝捆,位于F島的核電站,受9級(jí)特大地震影響懒豹,放射性物質(zhì)發(fā)生泄漏芙盘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一脸秽、第九天 我趴在偏房一處隱蔽的房頂上張望儒老。 院中可真熱鬧,春花似錦记餐、人聲如沸驮樊。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)囚衔。三九已至,卻和暖如春雕沿,著一層夾襖步出監(jiān)牢的瞬間练湿,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工晦炊, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鞠鲜,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓断国,卻偏偏與公主長(zhǎng)得像贤姆,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子稳衬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容

  • 下面是我自己收集整理的Java線程相關(guān)的面試題霞捡,可以用它來(lái)好好準(zhǔn)備面試。 參考文檔:-《Java核心技術(shù) 卷一》-...
    阿呆變Geek閱讀 14,767評(píng)論 14 507
  • 前言:雖然自己平時(shí)都在用多線程薄疚,也能完成基本的工作需求碧信,但總覺(jué)得,還是對(duì)線程沒(méi)有一個(gè)系統(tǒng)的概念街夭,所以砰碴,查閱了一些資...
    justCode_閱讀 701評(píng)論 0 9
  • 不管你是新程序員還是老手,你一定在面試中遇到過(guò)有關(guān)線程的問(wèn)題板丽。Java語(yǔ)言一個(gè)重要的特點(diǎn)就是內(nèi)置了對(duì)并發(fā)的支持呈枉,讓...
    堯淳閱讀 1,590評(píng)論 0 25
  • 【讀經(jīng)】 詩(shī)篇122-123 【金句】 人對(duì)我說(shuō):我們往耶和華的殿去,我就歡喜埃碱。(詩(shī)篇 122:1 和合本) 【感...
    chanor閱讀 399評(píng)論 0 0
  • 簡(jiǎn)單的Semaphore實(shí)現(xiàn) 使用Semaphore來(lái)發(fā)出信號(hào) 可計(jì)數(shù)的Semaphore 有上限的Semapho...
    vaneL閱讀 521評(píng)論 0 0