手机看片福利永久国产日韩-手机看片369-手机精品在线-手机国产乱子伦精品视频-国产精品嫩草影院在线观看免费-国产精品嫩草影院在线播放

首頁 新聞 > 科技 > 正文

多線程編程之:Linux線程概述

9.1 Linux線程概述

本文引用地址:http://www.eepw.com.cn/article/264052.htm

9.1.1 線程概述

前面已經提到,進程是系統中程序執行和資源分配的基本單位。每個進程都擁有自己的數據段、代碼段和堆棧段,這就造成了進程在進行切換等操作時都需要有比較復雜的上下文切換等動作。為了進一步減少處理機的空轉時間,支持多處理器以及減少上下文切換開銷,進程在演化中出現了另一個概念——線程。它是進程內獨立的一條運行路線,處理器調度的最小單元,也可以稱為輕量級進程。線程可以對進程的內存空間和資源進行訪問,并與同一進程中的其他線程共享。因此,線程的上下文切換的開銷比創建進程小很多。

同進程一樣,線程也將相關的執行狀態和存儲變量放在線程控制表內。一個進程可以有多個線程,也就是有多個線程控制表及堆棧寄存器,但卻共享一個用戶地址空間。要注意的是,由于線程共享了進程的資源和地址空間,因此,任何線程對系統資源的操作都會給其他線程帶來影響。由此可知,多線程中的同步是非常重要的問題。在多線程系統中,進程與進程的關系如圖9.1所示。

圖9.1 進程與線程關系

9.1.2 線程機制的分類和特性

線程按照其調度者可以分為用戶級線程和核心級線程兩種。

(1)用戶級線程。

用戶級線程主要解決的是上下文切換的問題,它的調度算法和調度過程全部由用戶自行選擇決定,在運行時不需要特定的內核支持。在這里,操作系統往往會提供一個用戶空間的線程庫,該線程庫提供了線程的創建、調度和撤銷等功能,而內核仍然僅對進程進行管理。如果一個進程中的某一個線程調用了一個阻塞的系統調用函數,那么該進程包括該進程中的其他所有線程也同時被阻塞。這種用戶級線程的主要缺點是在一個進程中的多個線程的調度中無法發揮多處理器的優勢。

(2)輕量級進程。

輕量級進程是內核支持的用戶線程,是內核線程的一種抽象對象。每個線程擁有一個或多個輕量級線程,而每個輕量級線程分別被綁定在一個內核線程上。

(3)內核線程。

這種線程允許不同進程中的線程按照同一相對優先調度方法進行調度,這樣就可以發揮多處理器的并發優勢。

現在大多數系統都采用用戶級線程與核心級線程并存的方法。一個用戶級線程可以對應一個或幾個核心級線程,也就是“一對一”或“多對一”模型。這樣既可滿足多處理機系統的需要,也可以最大限度地減少調度開銷。

使用線程機制大大加快上下文切換速度而且節省很多資源。但是因為在用戶態和內核態均要實現調度管理,所以會增加實現的復雜度和引起優先級翻轉的可能性。一個多線程程序的同步設計與調試也會增加程序實現的難度。

關鍵詞: Linux 多線程 內核

最近更新

關于本站 管理團隊 版權申明 網站地圖 聯系合作 招聘信息

Copyright © 2005-2018 創投網 - www.extremexp.net All rights reserved
聯系我們:33 92 950@qq.com
豫ICP備2020035879號-12

 

主站蜘蛛池模板: 久久综合一本| 再深点灬舒服灬快h视频| 日韩午夜视频在线观看| 黄色片三| 天天草b| 成人免费福利电影| 天天想你电视剧| 嗯~啊~哦~别~别停~啊老师| 放荡的女老板bd中文在线观看| 全部免费a级毛片| 7777精品久久久大香线蕉| 俺去ye| 95免费观看体验区视频| 成人免费视频观看无遮挡| 日本全套xxxx按摩| 久久伊人精品| 欧美交换乱理伦片120秒| 国产交换配乱吟播放免费| 国产精品9999久久久久| 亚洲日韩中文字幕天堂不卡| 波多野结衣bd| 处女影院| 再深点灬舒服灬在快点视频| 美女和男生一起差差差| 日韩精品一区二区三区在线观看 | yw在线观看成人免费| 久久99热66这里只有精品一| 果冻传媒和精东影业在线观看| 国产卡1卡2卡三卡在线| 欧美综合自拍亚洲综合图片区| 国产剧情麻豆剧果冻传媒视频免费 | 丰满肥臀风间由美357在线| 91精品麻豆| 夜夜春宵伴娇全文阅读| 英国性经典xxxx| 一级毛片无毒不卡直接观看| 精品一区二区三区3d动漫| 亚洲理论精品午夜电影| 狼群视频在线观看www| 黄色一级电影免费| 亚洲欧美日韩在线观看播放|