網(wǎng)絡(luò)消費(fèi)網(wǎng) >  5G > > 正文
        多線程編程之:Linux線程概述
        時(shí)間:2022-01-27 18:22:01

        9.1 Linux線程概述

        9.1.1 線程概述

        前面已經(jīng)提到,進(jìn)程是系統(tǒng)中程序執(zhí)行和資源分配的基本單位。每個(gè)進(jìn)程都擁有自己的數(shù)據(jù)段、代碼段和堆棧段,這就造成了進(jìn)程在進(jìn)行切換等操作時(shí)都需要有比較復(fù)雜的上下文切換等動(dòng)作。為了進(jìn)一步減少處理機(jī)的空轉(zhuǎn)時(shí)間,支持多處理器以及減少上下文切換開(kāi)銷,進(jìn)程在演化中出現(xiàn)了另一個(gè)概念——線程。它是進(jìn)程內(nèi)獨(dú)立的一條運(yùn)行路線,處理器調(diào)度的最小單元,也可以稱為輕量級(jí)進(jìn)程。線程可以對(duì)進(jìn)程的內(nèi)存空間和資源進(jìn)行訪問(wèn),并與同一進(jìn)程中的其他線程共享。因此,線程的上下文切換的開(kāi)銷比創(chuàng)建進(jìn)程小很多。

        同進(jìn)程一樣,線程也將相關(guān)的執(zhí)行狀態(tài)和存儲(chǔ)變量放在線程控制表內(nèi)。一個(gè)進(jìn)程可以有多個(gè)線程,也就是有多個(gè)線程控制表及堆棧寄存器,但卻共享一個(gè)用戶地址空間。要注意的是,由于線程共享了進(jìn)程的資源和地址空間,因此,任何線程對(duì)系統(tǒng)資源的操作都會(huì)給其他線程帶來(lái)影響。由此可知,多線程中的同步是非常重要的問(wèn)題。在多線程系統(tǒng)中,進(jìn)程與進(jìn)程的關(guān)系如圖9.1所示。

        圖9.1 進(jìn)程與線程關(guān)系

        9.1.2 線程機(jī)制的分類和特性

        線程按照其調(diào)度者可以分為用戶級(jí)線程和核心級(jí)線程兩種。

        (1)用戶級(jí)線程。

        用戶級(jí)線程主要解決的是上下文切換的問(wèn)題,它的調(diào)度算法和調(diào)度過(guò)程全部由用戶自行選擇決定,在運(yùn)行時(shí)不需要特定的內(nèi)核支持。在這里,操作系統(tǒng)往往會(huì)提供一個(gè)用戶空間的線程庫(kù),該線程庫(kù)提供了線程的創(chuàng)建、調(diào)度和撤銷等功能,而內(nèi)核仍然僅對(duì)進(jìn)程進(jìn)行管理。如果一個(gè)進(jìn)程中的某一個(gè)線程調(diào)用了一個(gè)阻塞的系統(tǒng)調(diào)用函數(shù),那么該進(jìn)程包括該進(jìn)程中的其他所有線程也同時(shí)被阻塞。這種用戶級(jí)線程的主要缺點(diǎn)是在一個(gè)進(jìn)程中的多個(gè)線程的調(diào)度中無(wú)法發(fā)揮多處理器的優(yōu)勢(shì)。

        (2)輕量級(jí)進(jìn)程。

        輕量級(jí)進(jìn)程是內(nèi)核支持的用戶線程,是內(nèi)核線程的一種抽象對(duì)象。每個(gè)線程擁有一個(gè)或多個(gè)輕量級(jí)線程,而每個(gè)輕量級(jí)線程分別被綁定在一個(gè)內(nèi)核線程上。

        (3)內(nèi)核線程。

        這種線程允許不同進(jìn)程中的線程按照同一相對(duì)優(yōu)先調(diào)度方法進(jìn)行調(diào)度,這樣就可以發(fā)揮多處理器的并發(fā)優(yōu)勢(shì)。

        現(xiàn)在大多數(shù)系統(tǒng)都采用用戶級(jí)線程與核心級(jí)線程并存的方法。一個(gè)用戶級(jí)線程可以對(duì)應(yīng)一個(gè)或幾個(gè)核心級(jí)線程,也就是“一對(duì)一”或“多對(duì)一”模型。這樣既可滿足多處理機(jī)系統(tǒng)的需要,也可以最大限度地減少調(diào)度開(kāi)銷。

        使用線程機(jī)制大大加快上下文切換速度而且節(jié)省很多資源。但是因?yàn)樵谟脩魬B(tài)和內(nèi)核態(tài)均要實(shí)現(xiàn)調(diào)度管理,所以會(huì)增加實(shí)現(xiàn)的復(fù)雜度和引起優(yōu)先級(jí)翻轉(zhuǎn)的可能性。一個(gè)多線程程序的同步設(shè)計(jì)與調(diào)試也會(huì)增加程序?qū)崿F(xiàn)的難度。

        關(guān)鍵詞: Linux 多線程 內(nèi)核

        版權(quán)聲明:
            凡注明來(lái)網(wǎng)絡(luò)消費(fèi)網(wǎng)的作品,版權(quán)均屬網(wǎng)絡(luò)消費(fèi)網(wǎng)所有,未經(jīng)授權(quán)不得轉(zhuǎn)載、摘編或利用其它方式使用上述作品。已經(jīng)本網(wǎng)授權(quán)使用作品的,應(yīng)在授權(quán)范圍內(nèi)使用,并注明"來(lái)源:網(wǎng)絡(luò)消費(fèi)網(wǎng)"。違反上述聲明者,本網(wǎng)將追究其相關(guān)法律責(zé)任。
            除來(lái)源署名為網(wǎng)絡(luò)消費(fèi)網(wǎng)稿件外,其他所轉(zhuǎn)載內(nèi)容之原創(chuàng)性、真實(shí)性、完整性、及時(shí)性本站不作任何保證或承諾,請(qǐng)讀者僅作參考并自行核實(shí)。
        熱文

        網(wǎng)站首頁(yè) |網(wǎng)站簡(jiǎn)介 | 關(guān)于我們 | 廣告業(yè)務(wù) | 投稿信箱
         

        Copyright © 2000-2020 www.fnsyft.com All Rights Reserved.
         

        中國(guó)網(wǎng)絡(luò)消費(fèi)網(wǎng) 版權(quán)所有 未經(jīng)書(shū)面授權(quán) 不得復(fù)制或建立鏡像
         

        聯(lián)系郵箱:920 891 263@qq.com

        備案號(hào):京ICP備2022016840號(hào)-15

        營(yíng)業(yè)執(zhí)照公示信息

        亚洲综合另类小说色区色噜噜| 中文字幕精品三区无码亚洲| 国产亚洲蜜芽精品久久| 亚洲欧洲日本在线观看| 亚洲无成人网77777| 亚洲精品成人图区| 亚洲视频在线观看不卡| 亚洲视频免费在线看| 亚洲高清中文字幕综合网| 亚洲视频在线观看免费视频| 亚洲综合久久成人69| 亚洲精品国产情侣av在线| 亚洲欧洲日产国码二区首页| 亚洲国产成人精品无码区在线秒播 | 麻豆亚洲AV成人无码久久精品 | 国产精品亚洲а∨无码播放麻豆 | 亚洲最大的成网4438| 亚洲美女视频一区二区三区| 亚洲第一永久在线观看| 亚洲三级在线免费观看| 亚洲影视自拍揄拍愉拍| 亚洲日韩精品无码AV海量| 亚洲成在人线在线播放无码| 精品亚洲视频在线| 亚洲国产日韩在线观频| 亚洲精品成人区在线观看| 亚洲香蕉网久久综合影视| 亚洲va久久久噜噜噜久久狠狠| 亚洲另类激情综合偷自拍| 亚洲综合综合在线| 亚洲男人天堂2022| 豆国产96在线|亚洲| 久久精品国产精品亚洲下载| 狠狠色伊人亚洲综合成人| 亚洲免费精彩视频在线观看| 亚洲国产精品久久网午夜| 亚洲色少妇熟女11p| 亚洲成a人一区二区三区| 亚洲熟妇无码八AV在线播放| 亚洲网站在线观看| 亚洲精品二三区伊人久久|