明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

C#的多線程機制探索(轉自天極網(wǎng))

[摘要]注:本文中出現(xiàn)的代碼均在.net Framework RC3環(huán)境中運行通過   一.多線程的概念 Windows是一個多任務的系統(tǒng),如果你使用的是windows 2000及其以上版本,你可以通過任務管理器查看當前系統(tǒng)運行的程序和進程。什么是進程呢?當一個程序開始運行時,它就是一個進程,進程所指...
注:本文中出現(xiàn)的代碼均在.net Framework RC3環(huán)境中運行通過

  一.多線程的概念



Windows是一個多任務的系統(tǒng),如果你使用的是windows 2000及其以上版本,你可以通過任務管理器查看當前系統(tǒng)運行的程序和進程。什么是進程呢?當一個程序開始運行時,它就是一個進程,進程所指包括運行中的程序和程序所使用到的內(nèi)存和系統(tǒng)資源。而一個進程又是由多個線程所組成的,線程是程序中的一個執(zhí)行流,每個線程都有自己的專有寄存器(棧指針、程序計數(shù)器等),但代碼區(qū)是共享的,即不同的線程可以執(zhí)行同樣的函數(shù)。多線程是指程序中包含多個執(zhí)行流,即在一個程序中可以同時運行多個不同的線程來執(zhí)行不同的任務,也就是說允許單個程序創(chuàng)建多個并行執(zhí)行的線程來完成各自的任務。瀏覽器就是一個很好的多線程的例子,在瀏覽器中你可以在下載JAVA小應用程序或圖象的同時滾動頁面,在訪問新頁面時,播放動畫和聲音,打印文件等。

多線程的好處在于可以提高CPU的利用率——任何一個程序員都不希望自己的程序很多時候沒事可干,在多線程程序中,一個線程必須等待的時候,CPU可以運行其它的線程而不是等待,這樣就大大提高了程序的效率。

然而我們也必須認識到線程本身可能影響系統(tǒng)性能的不利方面,以正確使用線程:
  • 線程也是程序,所以線程需要占用內(nèi)存,線程越多占用內(nèi)存也越多
  • 多線程需要協(xié)調和管理,所以需要CPU時間跟蹤線程
  • 線程之間對共享資源的訪問會相互影響,必須解決競用共享資源的問題
  • 線程太多會導致控制太復雜,最終可能造成很多Bug
基于以上認識,我們可以一個比喻來加深理解。假設有一個公司,公司里有很多各司其職的職員,那么我們可以認為這個正常運作的公司就是一個進程,而公司里的職員就是線程。一個公司至少得有一個職員吧,同理,一個進程至少包含一個線程。在公司里,你可以一個職員干所有的事,但是效率很顯然是高不起來的,一個人的公司也不可能做大;一個程序中也可以只用一個線程去做事,事實上,一些過時的語言如fortune,basic都是如此,但是象一個人的公司一樣,效率很低,如果做大程序,效率更低——事實上現(xiàn)在幾乎沒有單線程的商業(yè)軟件。公司的職員越多,老板就得發(fā)越多的薪水給他們,還得耗費大量精力去管理他們,協(xié)調他們之間的矛盾和利益;程序也是如此,線程越多耗費的資源也越多,需要CPU時間去跟蹤線程,還得解決諸如死鎖,同步等問題。總之,如果你不想你的公司被稱為“皮包公司”,你就得多幾個員工;如果你不想讓你的程序顯得稚氣,就在你的程序里引入多線程吧!

本文將對C#編程中的多線程機制進行探討,通過一些實例解決對線程的控制,多線程間通訊等問題。為了省去創(chuàng)建GUI那些繁瑣的步驟,更清晰地逼近線程的本質,下面所有的程序都是控制臺程序,程序最后的Console.ReadLine()是為了使程序中途停下來,以便看清楚執(zhí)行過程中的輸出。

好了,廢話少說,讓我們來體驗一下多線程的C#吧!

  二.操縱一個線程

任何程序在執(zhí)行時,至少有一個主線程,下面這段小程序可以給讀者一個直觀的印象:

//SystemThread.cs
using System;
using System.Threading;

namespace ThreadTest
{
  class RunIt
  {
    [STAThread]
    static void Main(string[] args)
    {
      Thread.CurrentThread.Name="System Thread";//給當前線程起名為"System Thread"
Console.WriteLine(Thread.CurrentThread.Name+"'Status:"+Thread.CurrentThread.ThreadState);
      Console.ReadLine();
    }
  }
}