chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

講講線程、進(jìn)程和CPU中的超線程

冬至配餃子 ? 來源:天奇工作室 ? 作者:LRC ? 2022-08-05 16:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

我們先來回顧一下之前的內(nèi)容。CPU其實(shí)就是執(zhí)行指令的器件,指令從哪讀取要看PC寄存器,取得的指令需要翻譯成電路的控制信號(hào),最后輸出一條指令的結(jié)果,這個(gè)結(jié)果可能會(huì)對(duì)下一條指令產(chǎn)生影響,也可能會(huì)對(duì)內(nèi)存或地址空間中的某個(gè)值產(chǎn)生影響。

今天我們來講講線程、進(jìn)程和CPU中的超線程。

我們通過不計(jì)其數(shù)的指令的組合,可以形成一個(gè)完整的線程。線程之間通過少量的必要的溝通組合形成一個(gè)進(jìn)程,也就是我們通常意義上的應(yīng)用程序。比如說音樂播放器中,音樂的播放是一個(gè)線程,用戶的操作界面是另外一個(gè)線程,兩個(gè)線程合起來構(gòu)成了音樂播放器。當(dāng)然,一個(gè)應(yīng)用程序(進(jìn)程)也可以只有一個(gè)線程。

早期的計(jì)算機(jī)不像現(xiàn)在如此發(fā)達(dá),一般一臺(tái)計(jì)算機(jī)一段時(shí)間內(nèi)只運(yùn)行一個(gè)線程,比如說計(jì)算導(dǎo)彈軌跡什么的,在計(jì)算完成后輸出結(jié)果,線程結(jié)束。然而時(shí)代在改變,在寫這段文字的時(shí)候,我的平板一邊打開著wps,一邊播放著音樂。這兩個(gè)進(jìn)程的運(yùn)行是連續(xù)的、同時(shí)的。

為什么會(huì)連續(xù)、同時(shí)呢?

首先,當(dāng)今的CPU的核心數(shù)早已不是單核心,一個(gè)非超線程(一會(huì)會(huì)講)的核心可以運(yùn)行一個(gè)線程,現(xiàn)在的八核CPU就可以同時(shí)運(yùn)行八個(gè)線程。但是這樣夠嗎?我們現(xiàn)在的電腦同一時(shí)刻需要運(yùn)行的線程可遠(yuǎn)不止八個(gè)。那看來光有核心數(shù)還不夠,我們還需要?jiǎng)e的辦法。

第二個(gè)辦法便是分時(shí)間片。CPU運(yùn)算速度極快,我們能不能讓CPU在這一些線程上反復(fù)橫跳,快速切換并輪流執(zhí)行這些個(gè)線程,營造出一種這些線程是同時(shí)進(jìn)行的錯(cuò)覺。具體怎么操作呢?可以設(shè)置一個(gè)“鬧鐘”,當(dāng)?shù)褂?jì)時(shí)結(jié)束的時(shí)候強(qiáng)行停止CPU當(dāng)前的線程(中斷),PC寄存器跳轉(zhuǎn)到相應(yīng)的地址,將當(dāng)前未處理完的線程的PC值、寄存器組數(shù)據(jù)等信息用一種數(shù)據(jù)類型保存到內(nèi)存中,CPU將根據(jù)操作系統(tǒng)給出的決定切換到接下來要運(yùn)行的下一個(gè)線程。CPU此時(shí)要將接下來要運(yùn)行的線程從內(nèi)存中讀取,恢復(fù)該線程到CPU內(nèi)核心中,就像它之前被切換出去時(shí)的樣子,然后開始執(zhí)行這個(gè)線程。(暫不細(xì)講)

第三個(gè)方法則是今天的主角--超線程技術(shù)。這個(gè)技術(shù)我沒記錯(cuò)的話是Intel率先提出來的,他們聲稱增加5%的晶體管數(shù)量可以提升20%的性能。

具體怎么操作呢?首先我們先要考慮一下為什么一個(gè)核心只能同時(shí)運(yùn)行一個(gè)線程。

1.只有一個(gè)PC寄存器,只能指示一個(gè)線程目前運(yùn)行到哪了。

2.無法區(qū)分對(duì)寄存器組的操作。比如線程A要把第一個(gè)寄存器的值寫成0,B要讀出第一個(gè)寄存器的值,現(xiàn)在也就是0。但這個(gè)0是B想要的嗎?肯定不是。

3.還有一些涉及到線程的棧指針和頁表基地址的寄存器,也只能支撐一個(gè)線程的運(yùn)行。

因此,超線程簡單來講就是把這些不能公用的資源加倍。而那些流水線上的操作邏輯電路、ALU單元等則可以不用復(fù)制。以此實(shí)現(xiàn)多個(gè)線程同時(shí)在一個(gè)CPU的核心中進(jìn)行處理。注意,不一定一個(gè)核心只能虛擬出兩個(gè)線程,IBM的某款CPU甚至一個(gè)核心虛擬出了八個(gè)線程。

那為什么性能會(huì)提升呢?共用了這么多資源,性能應(yīng)該會(huì)有所下降才對(duì)。是的,有些時(shí)候性能確實(shí)會(huì)下滑,尤其是某個(gè)線程需要很大計(jì)算量的時(shí)候,因?yàn)楣灿茫赡軙?huì)導(dǎo)致該線程運(yùn)行速度減慢。那Intel是瞎吹他們的超線程技術(shù)嗎?并不是,往往CPU限制運(yùn)行速度的不是計(jì)算而是讀寫。讀寫要做的就是等待數(shù)據(jù)的傳輸,這個(gè)過程CPU沒事可做,只能空等。但有了超線程就不一樣了,CPU可以在本該空等的地方擇機(jī)執(zhí)行另外一個(gè)線程的指令,實(shí)現(xiàn)了時(shí)間管理,縮短了兩個(gè)程序執(zhí)行的總體時(shí)間。


審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5434

    瀏覽量

    124577
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11080

    瀏覽量

    217152
  • ALU
    ALU
    +關(guān)注

    關(guān)注

    0

    文章

    34

    瀏覽量

    13317
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    UVC+MSC實(shí)現(xiàn)MSC線程未運(yùn)行的原因?

    我正在嘗試使用 EZUSB 運(yùn)行 UVC + MSC。我有以下內(nèi)容。但看起來只有 UVC 線程在運(yùn)行,而 MSC 沒有運(yùn)行。fw 不響應(yīng) MSC 命令。我確保 LPM 已被禁用,只是為了檢查傳感器
    發(fā)表于 07-16 07:08

    深度剖析 RT-Thread 線程調(diào)度流程

    rt_system_scheduler_start:調(diào)度系統(tǒng)第一個(gè)線程rt_hw_context_switch_to:初始化上下文切換環(huán)境,觸發(fā)PendSV異常first_thread:系統(tǒng)優(yōu)先級(jí)最高
    的頭像 發(fā)表于 06-25 18:24 ?709次閱讀
    深度剖析 RT-Thread <b class='flag-5'>線程</b>調(diào)度流程

    線程的安全注意事項(xiàng)

    線程安全是指多個(gè)線程同時(shí)訪問或修改共享資源時(shí),能夠保證程序的正確性和可靠性。 開發(fā)者選擇TaskPool或Worker進(jìn)行多線程開發(fā)時(shí),在TaskPool和Worker的工作線程中導(dǎo)
    發(fā)表于 06-20 07:49

    鴻蒙5開發(fā)寶藏案例分享---跨線程性能優(yōu)化指南

    [] = []; // 3. 子線程按需查詢數(shù)據(jù) static async getAuthors(ids: number[]): Promise<string[]> { return
    發(fā)表于 06-12 17:13

    進(jìn)程、線程、協(xié)程傻傻分不清?一文帶你徹底扒光它們的\"底褲\"!

    ;) ? asyncio.run(main()) 輸出結(jié)果: markdown 抓取完成!共 10 條數(shù)據(jù) 「三大門派」終極對(duì)比表(含「社死」現(xiàn)場) 特性 進(jìn)程 線程 協(xié)程 資源開銷 高(買房) (合租
    發(fā)表于 03-26 09:27

    請(qǐng)問如何在Python實(shí)現(xiàn)多線程與多進(jìn)程的協(xié)作?

    () thread.join() process.join() 我的問題是:**如何合理地組合多線程和多進(jìn)程以獲得更好的性能?**特別是在I/O密集型任務(wù)和CPU密集型任務(wù)混合的情況下,如何避免性能瓶頸,確保程序的高效運(yùn)行? 希
    發(fā)表于 03-11 06:57

    請(qǐng)問rt-thread studio如何進(jìn)行多線程編譯?

    ,使用的是5800h+32g內(nèi)存+sn550 ssd,開啟16線程編譯時(shí)cpu的占用率也只能到30%,編譯完整個(gè)工程需要3分鐘 感覺多線程編譯設(shè)置沒有生效,有辦法提高編譯速度嗎
    發(fā)表于 02-19 08:30

    華為云 X 實(shí)例 CPU 性能測試詳解與優(yōu)化策略

    ? 2.2 Sysbench單線程CPU性能測試 ? 2.3 Sysbench多線程CPU性能測試(4線程) ? 2.4 高強(qiáng)度多
    的頭像 發(fā)表于 12-30 14:52 ?684次閱讀
    華為云 X 實(shí)例 <b class='flag-5'>CPU</b> 性能測試詳解與優(yōu)化策略

    國產(chǎn)GPU獨(dú)角獸摩爾線程啟動(dòng)上市輔導(dǎo)

    近日,國內(nèi)GPU領(lǐng)域的獨(dú)角獸企業(yè)摩爾線程正式在北京證監(jiān)局辦理了上市輔導(dǎo)備案登記,標(biāo)志著其A股上市進(jìn)程已全面啟動(dòng)。此次輔導(dǎo)機(jī)構(gòu)選定為中信證券,將為摩爾線程的上市之路提供有力支持。
    的頭像 發(fā)表于 11-14 14:21 ?596次閱讀

    socket 多線程編程實(shí)現(xiàn)方法

    是指在同一個(gè)進(jìn)程運(yùn)行多個(gè)線程,每個(gè)線程可以獨(dú)立執(zhí)行任務(wù)。線程共享進(jìn)程的資源,如內(nèi)存空間和文件句
    的頭像 發(fā)表于 11-12 14:16 ?1020次閱讀

    摩爾線程完成股改,籌備上市

    近日,摩爾線程智能科技(北京)股份有限公司(簡稱“摩爾線程”)宣布已完成股改,并正積極籌備上市。據(jù)國家企業(yè)信用信息公示系統(tǒng)最新查詢結(jié)果顯示,摩爾線程的市場主體類型在10月28日已從其他有限責(zé)任公司
    的頭像 發(fā)表于 11-12 14:15 ?1180次閱讀

    一文搞懂Linux進(jìn)程的睡眠和喚醒

    。通過PPID,可以追蹤進(jìn)程的來源,并了解進(jìn)程之間的關(guān)系。 在PCB記錄的進(jìn)程狀態(tài),不過是一些整數(shù),這個(gè)整數(shù)是多少就代表進(jìn)程此時(shí)處于什么
    發(fā)表于 11-04 15:15

    Python線程和多進(jìn)程的區(qū)別

    Python作為一種高級(jí)編程語言,提供了多種并發(fā)編程的方式,其中多線程與多進(jìn)程是最常見的兩種方式之一。在本文中,我們將探討Python線程與多進(jìn)
    的頭像 發(fā)表于 10-23 11:48 ?1023次閱讀
    Python<b class='flag-5'>中</b>多<b class='flag-5'>線程</b>和多<b class='flag-5'>進(jìn)程</b>的區(qū)別

    CPU線程和程序線程的區(qū)別

    CPU線程與程序的線程在概念、作用、實(shí)現(xiàn)方式以及性能影響等方面存在顯著差異。以下是對(duì)兩者區(qū)別的詳細(xì)闡述,旨在深入探討這一技術(shù)話題。
    的頭像 發(fā)表于 09-02 11:18 ?2133次閱讀

    一文掌握Python多線程

    使用線程可以把占據(jù)長時(shí)間的程序的任務(wù)放到后臺(tái)去處理。
    的頭像 發(fā)表于 08-05 15:46 ?1270次閱讀