更新時(shí)間:2021-02-14 10:31:43 來(lái)源:動(dòng)力節(jié)點(diǎn) 瀏覽2240次
CPU中的線程和操作系統(tǒng)(OS)中的線程顯然是兩個(gè)不同的概念,但是在實(shí)際調(diào)度的時(shí)候又有些關(guān)聯(lián)。本文我們就來(lái)弄清楚,CPU中的線程和操作系統(tǒng)中的線程到底有什么區(qū)別。
一、CPU中的Thread
CPU中的線程,我們叫它們Thread,和OS中的線程的名字一樣。它來(lái)自同步多線程(SMT,Simultaneous Multi-threading)的概念。我們現(xiàn)在在Intel的CPU上看到它,實(shí)際上這并不是Intel的發(fā)明創(chuàng)造。它最早起源于學(xué)術(shù)圈,在硬件上IBM實(shí)現(xiàn)也比Intel早。最早Intel使用了這種技術(shù)時(shí)候就叫做SMT,但后面改叫做HT (Hyper Threading),可能是這樣更清楚(畢竟最多兩個(gè)thread,比IBM怪物要少),更朗朗上口吧。
我們現(xiàn)在看到CPU,很多都支持HT,經(jīng)常看到的2C4T的意思就是2核4線程(T,Thread)。1個(gè)內(nèi)核中的thread是對(duì)稱的和對(duì)等的,在軟件上沒(méi)有任何區(qū)別,BIOS也只有通過(guò)一些特殊手段才能區(qū)分。實(shí)際上,2C4T中的4個(gè)thread調(diào)度起來(lái)沒(méi)有本質(zhì)區(qū)別,它們都有自己?jiǎn)为?dú)的身份證號(hào)碼:APIC ID。調(diào)度起來(lái)只要知道別人的APIC ID,就用自己的Local APIC寄存器發(fā)出兩個(gè)IPI(Inter-Processor Interrupts)就好了,那個(gè)被指明的倒霉蛋就莫名其妙的開始被調(diào)度去指定的地址執(zhí)行指令了(盡管是實(shí)模式)。當(dāng)然也可以廣播IPI讓所有別的thread都去執(zhí)行指定任務(wù)。
實(shí)際上CPU中Thead有多少,操作系統(tǒng)并不自己探測(cè),是BIOS通過(guò)ACPI報(bào)告給OS的,那么BIOS是怎么知道有多少個(gè)Thread呢?就是通過(guò)廣播IPI讓各個(gè)thread自己來(lái)簽到的,是不是很簡(jiǎn)單?
二、操作系統(tǒng)中的Thread
OS中的Thread有自己的??臻g,和同一進(jìn)程中的其他線程共享地址空間等等,這些基本知識(shí)因?yàn)閺V為人所知,這里就不羅嗦了。
此Thread非彼Thread
操作系統(tǒng)中的進(jìn)程可以很多,進(jìn)程中的線程就更多了,常常有幾十個(gè)上百個(gè)。而CPU的Thread就那么固定幾個(gè),是稀缺資源。兩者都叫Thread是因?yàn)樗麄兌际钦{(diào)度的基本單位,軟件操作系統(tǒng)調(diào)度的基本單位是OS的Thread,硬件的調(diào)度基本單位是CPU中的Thread。操作系統(tǒng)負(fù)責(zé)把它產(chǎn)生的軟Thread調(diào)度到CPU中的硬Thread中去。
以上就是CPU中的線程和操作系統(tǒng)(OS)中的線程的簡(jiǎn)單的區(qū)別,我們?cè)谡{(diào)用這兩個(gè)線程的時(shí)候,他們之間也會(huì)產(chǎn)生某種聯(lián)系。在本站的多線程教程中還有很多類似的蔣蔣,能過(guò)有效幫助我們掌握相關(guān)的信息和資訊。
相關(guān)閱讀
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
有基礎(chǔ) 直達(dá)就業(yè)
業(yè)余時(shí)間 高薪轉(zhuǎn)行
工作1~3年,加薪神器
工作3~5年,晉升架構(gòu)
提交申請(qǐng)后,顧問(wèn)老師會(huì)電話與您溝通安排學(xué)習(xí)
初級(jí) 202925
初級(jí) 203221
初級(jí) 202629
初級(jí) 203743