青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

cc

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  38 隨筆 :: 14 文章 :: 21 評論 :: 0 Trackbacks

在.NET多線程編程這個系列我們講一起來探討多線程編程的各個方面。首先我將在本篇文章的開始向大家介紹多線程的有關概念以及多線程編程的基礎知識;在接下來的文章中,我將逐一講述。NET平臺上多線程編程的知識,諸如System.Threading命名空間的重要類以及方法,并就一些例子程序來作說明。

引言

  早期的計算硬件十分復雜,但是操作系統(tǒng)執(zhí)行的功能確十分的簡單。那個時候的操作系統(tǒng)在任一時間點只能執(zhí)行一個任務,也就是同一時間只能執(zhí)行一個程序。多個任務的執(zhí)行必須得輪流執(zhí)行,在系統(tǒng)里面進行排隊等候。由于計算機的發(fā)展,要求系統(tǒng)功能越來越強大,這個時候出現(xiàn)了分時操作的概念:每個運行的程序占有一定的處理機時間,當這個占有時間結(jié)束后,在等待隊列等待處理器資源的下一個程序就開始投入運行。注意這里的程序在占有一定的處理器時間后并沒有運行完畢,可能需要再一次或多次分配處理器時間。那么從這里可以看出,這樣的執(zhí)行方式顯然是多個程序的并行執(zhí)行,但是在宏觀上,我們感覺到多個任務是同時執(zhí)行的,因此多任務的概念就誕生了。每個運行的程序都有自己的內(nèi)存空間,自己的堆棧和環(huán)境變量設置。每一個程序?qū)粋€進程,代表著執(zhí)行一個大的任務。一個進程可以啟動另外一個進程,這個被啟動的進程稱為子進程。父進程和子進程的執(zhí)行只有邏輯上的先后關系,并沒有其他的關系,也就是說他們的執(zhí)行是獨立的。但是,可能一個大的程序(代表著一個大的任務),可以分割成很多的小任務,為了功能上的需要也有可能是為了加快運行的速度,可能需要同一時間執(zhí)行多個任務(每個任務分配一個多線程來執(zhí)行相應的任務)。舉個例子來說,你正在通過你的web瀏覽器查看一些精彩的文章,你需要把好的文章給下載下來,可能有些非常精彩的文章你需要收藏起來,你就用你的打印機打印這些在線的文章。在這里,瀏覽器一邊下載HTML格式的文章,一邊還要打印文章。這就是一個程序同時執(zhí)行多個任務,每個任務分配一個線程來完成。因此我們可以看出一個程序同時執(zhí)行多個任務的能力是通過多線程來實現(xiàn)的。


多線程VS多任務

  正如上面所說的,多任務是相對與操作系統(tǒng)而言,指的是同一時間執(zhí)行多個程序的能力,雖然這么說,但是實際上在只有一個CPU的條件下不可能同時執(zhí)行兩個以上的程序。CPU在程序之間做高速的切換,使得所有的程序在很短的時間之內(nèi)可以得到更小的CPU時間,這樣從用戶的角度來看就好象是同時在執(zhí)行多個程序。多線程相對于操作系統(tǒng)而言,指的是可以同時執(zhí)行同一個程序的不同部分的能力,每個執(zhí)行的部分被成為線程。所以在編寫應用程序時,我們必須得很好的設計以 避免不同的線程執(zhí)行時的相互干擾。這樣有助于我們設計健壯的程序,使得我們可以在隨時需要的時候添加線程。


線程的概念

  線程可以被描述為一個微進程,它擁有起點,執(zhí)行的順序系列和一個終點。它負責維護自己的堆棧,這些堆棧用于異常處理,優(yōu)先級調(diào)度和其他一些系統(tǒng)重新恢復線程執(zhí)行時需要的信息。從這個概念看來,好像線程與進程沒有任何的區(qū)別,實際上線程與進程是肯定有區(qū)別的:

  一個完整的進程擁有自己獨立的內(nèi)存空間和數(shù)據(jù),但是同一個進程內(nèi)的線程是共享內(nèi)存空間和數(shù)據(jù)的。一個進程對應著一段程序,它是由一些在同一個程序里面獨立的同時的運行的線程組成的。線程有時也被稱為并行運行在程序里的輕量級進程,線程被稱為是輕量級進程是因為它的運行依賴與進程提供的上下文環(huán)境,并且使用的是進程的資源。

  在一個進程里,線程的調(diào)度有搶占式或者非搶占的模式。

  在搶占模式下,操作系統(tǒng)負責分配CPU時間給各個進程,一旦當前的進程使用完分配給自己的CPU時間,操作系統(tǒng)將決定下一個占用CPU時間的是哪一個線程。因此操作系統(tǒng)將定期的中斷當前正在執(zhí)行的線程,將CPU分配給在等待隊列的下一個線程。所以任何一個線程都不能獨占CPU。每個線程占用CPU的時間取決于進程和操作系統(tǒng)。進程分配給每個線程的時間很短,以至于我們感覺所有的線程是同時執(zhí)行的。實際上,系統(tǒng)運行每個進程的時間有2毫秒,然后調(diào)度其他的線程。它同時他維持著所有的線程和循環(huán),分配很少量的CPU時間給線程。 線程的的切換和調(diào)度是如此之快,以至于感覺是所有的線程是同步執(zhí)行的。

  調(diào)度是什么意思?調(diào)度意味著處理器存儲著將要執(zhí)行完CPU時間的進程的狀態(tài)和將來某個時間裝載這個進程的狀態(tài)而恢復其運行。然而這種方式也有不足之處,一個線程可以在任何給定的時間中斷另外一個線程的執(zhí)行。假設一個線程正在向一個文件做寫操作,而另外一個線程中斷其運行,也向同一個文件做寫操作。 Windows 95/NT, UNIX使用的就是這種線程調(diào)度方式。

  在非搶占的調(diào)度模式下,每個線程可以需要CPU多少時間就占用CPU多少時間。在這種調(diào)度方式下,可能一個執(zhí)行時間很長的線程使得其他所有需要CPU的線程”餓死”。在處理機空閑,即該進程沒有使用CPU時,系統(tǒng)可以允許其他的進程暫時使用CPU。占用CPU的線程擁有對CPU的控制權(quán),只有它自己主動釋放CPU時,其他的線程才可以使用CPU。一些I/O和Windows 3。x就是使用這種調(diào)度策略。

  在有些操作系統(tǒng)里面,這兩種調(diào)度策略都會用到。非搶占的調(diào)度策略在線程運行優(yōu)先級一般時用到,而對于高優(yōu)先級的線程調(diào)度則多采用搶占式的調(diào)度策略。如果你不確定系統(tǒng)采用的是那種調(diào)度策略,假設搶占的調(diào)度策略不可用是比較安全的。在設計應用程序的時候,我們認為那些占用CPU時間比較多的線程在一定的間隔是會釋放CPU的控制權(quán)的,這時候系統(tǒng)會查看那些在等待隊列里面的與當前運行的線程同一優(yōu)先級或者更高的優(yōu)先級的線程,而讓這些線程得以使用CPU。如果系統(tǒng)找到一個這樣的線程,就立即暫停當前執(zhí)行的線程和激活滿足條件的線程。如果沒有找到同一優(yōu)先級或更高級的線程,當前線程還繼續(xù)占有CPU。當正在執(zhí)行的線程想釋放CPU的控制權(quán)給一個低優(yōu)先級的線程,當前線程就轉(zhuǎn)入睡眠狀態(tài)而讓低優(yōu)先級的線程占有CPU。

  在多處理器系統(tǒng),操作系統(tǒng)會將這些獨立的線程分配給不同的處理器執(zhí)行,這樣將會大大的加快程序的運行。線程執(zhí)行的效率也會得到很大的提高,因為將線程的分時共享單處理器變成了分布式的多處理器執(zhí)行。這種多處理器在三維建模和圖形處理是非常有用的。


需要多線程嗎

  我們發(fā)出了一個打印的命令,要求打印機進行打印任務,假設這時候計算機停止了響應而打印機還在工作,那豈不是我們的停止手上的事情就等著這慢速的打印機打印?所幸的是,這種情況不會發(fā)生,我們在打印機工作的時候還可以同時聽音樂或者畫圖。因為我們使用了獨立的多線程來執(zhí)行這些任務。你可能會對多個用戶同時訪問數(shù)據(jù)庫或者web服務器感到吃驚,他們是怎么工作的?這是因為為每個連接到數(shù)據(jù)庫或者web服務器的用戶建立了獨立的線程來維護用戶的狀態(tài)。如果一個程序的運行有一定的順序,這時候采用這種方式可能會出現(xiàn)問題,甚至導致整個程序崩潰。如果程序可以分成獨立的不同的任務,使用多線程,即使某一部分任務失敗了,對其他的也沒有影響,不會導致整個程序崩潰。

  毫無疑問的是,編寫多線程程序使得你有了一個利器可以駕奴非多線程的程序,但是多線程也可能成為一個負擔或者需要不小的代價。如果使用的不當,會帶來更多的壞處。如果一個程序有很多的線程,那么其他程序的線程必然只能占用更少的CPU時間;而且大量的CPU時間是用于線程調(diào)度的;操作系統(tǒng)也需要足夠的內(nèi)存空間來維護每個線程的上下文信息;因此,大量的線程會降低系統(tǒng)的運行效率。因此,如果使用多線程的話,程序的多線程必須設計的很好,否則帶來的好處將遠小于壞處。因此使用多線程我們必須小心的處理這些線程的創(chuàng)建,調(diào)度和釋放工作。


多線程程序設計提示

  有多種方法可以設計多線程的應用程序。正如后面的文章所示,我將給出詳細的編程示例,通過這些例子,你將可以更好的理解多線程。線程可以有不同的優(yōu)先級,舉例子來說,在我們的應用程序里面,繪制圖形或者做大量運算的同時要接受用戶的輸入,顯然用戶的輸入需要得到第一時間的響應,而圖形繪制或者運算則需要大量的時間,暫停一下問題不大,因此用戶輸入線程將需要高的悠閑級,而圖形繪制或者運算低優(yōu)先級即可。這些線程之間相互獨立,相互不影響。

  在上面的例子中,圖形繪制或者大量的運算顯然是需要站用很多的CPU時間的,在這段時間,用戶沒有必要等著他們執(zhí)行完畢再輸入信息,因此我們將程序設計成獨立的兩個線程,一個負責用戶的輸入,一個負責處理那些耗時很長的任務。這將使得程序更加靈活,能夠快速響應。同時也可以使得用戶在運行的任何時候取消任務的可能。在這個繪制圖形的例子中,程序應該始終負責接收系統(tǒng)發(fā)來的消息。如果由于程序忙于一個任務,有可能會導致屏幕變成空白,這顯然需要我們的程序來處理這樣的事件。所以我必須得有一個線程負責來處理這些消息,正如剛才所說的應該觸發(fā)重畫屏幕的工作。

  我們應該把握一個原則,對于那些對時間要求比較緊迫需要立即得到相應的任務,我們因該給予高的優(yōu)先級,而其他的線程優(yōu)先級應該低于她的優(yōu)先級。偵聽客戶端請求的線程應該始終是高的優(yōu)先級,對于一個與用戶交互的用戶界面的任務來說,它需要得到第一時間的響應,其優(yōu)先級因該高優(yōu)先級。

posted on 2006-12-07 15:03 醒目西西 閱讀(165) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            伊人久久久大香线蕉综合直播 | 亚洲欧美第一页| 欧美激情亚洲视频| 亚洲美女在线国产| 亚洲国产欧洲综合997久久| 久久天堂av综合合色| 激情综合色丁香一区二区| 久久综合九色综合久99| 久久婷婷一区| 在线午夜精品| 午夜精品久久久久久久99樱桃 | 欧美大片在线观看一区二区| 亚洲国产精品久久| 亚洲精品网站在线播放gif| 欧美性猛交99久久久久99按摩| 亚洲一区二区三区中文字幕| 午夜日韩在线| 亚洲国产免费| 亚洲视频一区二区| 国产综合色一区二区三区| 欧美激情在线免费观看| 欧美日韩亚洲一区二区三区在线观看| 在线中文字幕不卡| 欧美一二三区精品| 99视频日韩| 香蕉免费一区二区三区在线观看| 在线精品福利| 一区二区三区黄色| 亚洲二区视频| 亚洲一区二区毛片| 亚洲精品极品| 欧美在线视频日韩| 夜夜嗨一区二区三区| 欧美一区亚洲| 亚洲永久免费观看| 久久一区欧美| 欧美一区二区在线| 欧美精品免费视频| 久久噜噜亚洲综合| 国产精品久久7| 亚洲激情欧美| 在线看片欧美| 午夜天堂精品久久久久| 99re66热这里只有精品3直播| 亚洲欧美另类在线| 亚洲香蕉伊综合在人在线视看| 久久久久免费观看| 欧美一区二区三区视频免费播放 | 一区二区免费在线播放| 在线观看亚洲一区| 午夜精品理论片| 亚洲在线电影| 欧美国产精品专区| 女生裸体视频一区二区三区| 国产欧美日韩视频| 亚洲视频二区| 亚洲一卡久久| 欧美三级资源在线| 亚洲国产日韩一区二区| 在线观看成人一级片| 欧美中文字幕第一页| 午夜精品久久久久久久久久久 | 午夜精品久久久久影视| 在线视频精品一| 欧美精品一区二区三区蜜桃| 欧美激情视频一区二区三区免费 | 亚洲人线精品午夜| 久久免费精品日本久久中文字幕| 欧美亚洲一区二区在线| 国产精品久久久久久久久免费桃花| 亚洲国产精品小视频| 另类综合日韩欧美亚洲| 亚洲色图自拍| 欧美系列精品| 夜夜嗨网站十八久久| 99re热这里只有精品免费视频| 欧美成人一区在线| 亚洲片国产一区一级在线观看| 亚洲人成久久| 欧美视频久久| 亚洲视频综合在线| 欧美制服丝袜| 狠狠色狠狠色综合日日五| 久久久久久伊人| 亚洲精品国产精品国产自| 一区二区三区日韩欧美| 国产精品美女久久福利网站| 亚洲欧美日韩成人高清在线一区| 久久精品91久久香蕉加勒比 | 久久久精品动漫| 欧美电影免费网站| 在线亚洲精品福利网址导航| 国产精品免费网站| 久久久久久91香蕉国产| 亚洲二区视频| 亚洲欧美日韩天堂一区二区| 国产一区二区视频在线观看| 久久一区二区视频| 一区二区国产精品| 老鸭窝91久久精品色噜噜导演| 亚洲欧洲日韩综合二区| 国产精品白丝jk黑袜喷水| 亚洲欧美成人一区二区在线电影| 欧美成人免费全部观看天天性色| 日韩一级不卡| 国内成人精品视频| 欧美三级资源在线| 久久婷婷国产麻豆91天堂| 亚洲美女电影在线| 久久婷婷国产综合精品青草| 一区二区成人精品| 国内精品免费在线观看| 欧美日韩免费一区二区三区视频| 午夜精品成人在线视频| 亚洲精品一区中文| 蜜臀久久99精品久久久画质超高清 | 久久精品国产亚洲高清剧情介绍| 欧美高清视频在线| 久久国产精品黑丝| 日韩午夜激情电影| 伊人伊人伊人久久| 国产精品视频久久久| 欧美激情综合在线| 久久久国产精品亚洲一区| 亚洲免费在线电影| 亚洲乱码国产乱码精品精98午夜| 久久久久久一区二区| 亚洲一区二区三区视频播放| 亚洲国产视频一区二区| 国产一区二区三区视频在线观看| 欧美日韩国产经典色站一区二区三区| 久久久91精品国产一区二区三区 | 欧美午夜精品久久久久免费视| 久久久精品欧美丰满| 亚洲男同1069视频| 亚洲素人在线| 一区二区三区免费看| 亚洲欧洲日产国产综合网| 欧美不卡一区| 免费国产自线拍一欧美视频| 久久综合色88| 久久九九精品| 午夜精品久久久久久久99黑人| 亚洲网址在线| 亚洲欧美日本日韩| 亚洲欧美不卡| 亚洲欧美电影在线观看| 亚洲综合色在线| 午夜精品福利在线| 久久成人国产精品| 久久久国产视频91| 久久久久久一区二区三区| 久久亚洲精品一区二区| 久久尤物视频| 欧美成ee人免费视频| 亚洲国产女人aaa毛片在线| 欧美国产专区| 亚洲精品一区久久久久久| 日韩视频一区二区三区| 夜夜夜精品看看| 亚洲摸下面视频| 久久精品麻豆| 欧美91大片| 国产精品嫩草99a| 国自产拍偷拍福利精品免费一| 国内视频精品| 亚洲麻豆一区| 午夜久久福利| 狼狼综合久久久久综合网 | 欧美亚洲一级| 久久亚洲私人国产精品va| 欧美不卡在线视频| 9色porny自拍视频一区二区| 亚洲专区一区二区三区| 久久久久99精品国产片| 欧美金8天国| 国产精品稀缺呦系列在线| 伊人狠狠色j香婷婷综合| 亚洲精品一区二区三| 亚洲宅男天堂在线观看无病毒| 久久国产天堂福利天堂| 亚洲国产精品va在看黑人| 亚洲视频网站在线观看| 玖玖视频精品| 国产日韩一区| 一区二区三区高清不卡| 久久久之久亚州精品露出| 亚洲精品乱码久久久久久久久| 午夜一区不卡| 欧美日韩视频一区二区| 在线观看一区二区视频| 亚洲欧美日韩综合| 欧美国产免费| 亚洲欧美日韩另类| 欧美精品在线一区二区三区| 国产一区二区三区自拍| 亚洲欧美国产va在线影院| 欧美大片在线观看| 欧美一区综合| 国产精品国产三级国产专播精品人|