[.Net線程處理系列]專題六:線程同步——信號(hào)量和互斥體

也不多說了,直接進(jìn)入主題了

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:申請(qǐng)域名雅安服務(wù)器托管、營(yíng)銷軟件、網(wǎng)站建設(shè)、合水網(wǎng)站維護(hù)、網(wǎng)站推廣。

一、信號(hào)量(Semaphore)

信號(hào)量(Semaphore)是由內(nèi)核對(duì)象維護(hù)的int變量,當(dāng)信號(hào)量為0時(shí),在信號(hào)量上等待的線程會(huì)堵塞,信號(hào)量大于0時(shí),就解除堵塞。當(dāng)在一個(gè)信號(hào)量上等待的線程解除堵塞時(shí),內(nèi)核自動(dòng)會(huì)將信號(hào)量的計(jì)數(shù)減1。在.net 下通過Semaphore類來實(shí)現(xiàn)信號(hào)量同步。

Semaphore類限制可同時(shí)訪問某一資源或資源池的線程數(shù)。線程通過調(diào)用 WaitOne方法將信號(hào)量減1,并通過調(diào)用 Release方法把信號(hào)量加1。

先說下構(gòu)造函數(shù):

public Semaphore(int initialCount,int maximumCount);通過兩個(gè)參數(shù)來設(shè)置信號(hào)的初始計(jì)數(shù)和最大計(jì)數(shù)。

下面通過一段代碼來演示信號(hào)量同步的使用:

 
  1. class Program  
  2.     {  
  3.         // 初始信號(hào)量計(jì)數(shù)為0,最大計(jì)數(shù)為10 
  4.         public static Semaphore semaphore =new Semaphore(0,10);  
  5.         public static int time = 0;  
  6.         static void Main(string[] args)  
  7.         {  
  8.             for (int i = 0; i < 5; i++)  
  9.             {  
  10.                 Thread test = new Thread(new ParameterizedThreadStart(TestMethod));  
  11.  
  12.                 // 開始線程,并傳遞參數(shù) 
  13.                 test.Start(i);  
  14.             }  
  15.  
  16.             // 等待1秒讓所有線程開始并阻塞在信號(hào)量上 
  17.             Thread.Sleep(500);  
  18.  
  19.             // 信號(hào)量計(jì)數(shù)加4 
  20.             // 最后可以看到輸出結(jié)果次數(shù)為4次 
  21.             semaphore.Release(4);  
  22.             Console.Read();           
  23.         }  
  24.  
  25.         public static void TestMethod(object number)  
  26.         {  
  27.             // 設(shè)置一個(gè)時(shí)間間隔讓輸出有順序 
  28.             int span = Interlocked.Add(ref time, 100);  
  29.             Thread.Sleep(1000 + span);  
  30.  
  31.             //信號(hào)量計(jì)數(shù)減1 
  32.             semaphore.WaitOne();  
  33.               
  34.             Console.WriteLine("Thread {0} run ", number);  
  35.         }  
  36.     } 
運(yùn)行結(jié)果:[.Net線程處理系列]專題六:線程同步——信號(hào)量和互斥體

 同樣信號(hào)量也可以實(shí)現(xiàn)進(jìn)程中線程的同步,同樣也是通過對(duì)信號(hào)量命名來實(shí)現(xiàn)的,

通過調(diào)用public Semaphore(int initialCount,int maximumCount,string name);該構(gòu)造函數(shù)多傳入一個(gè)信號(hào)量名來實(shí)現(xiàn)

下面一段實(shí)例代碼來演示下:

  1. using System;  
  2. using System.Threading;  
  3.  
  4. namespace SemaphoreSample  
  5. {  
  6.     class Program  
  7.     {  
  8.         // 初始信號(hào)量計(jì)數(shù)為4,最大計(jì)數(shù)為10 
  9.         public static Semaphore semaphore =new Semaphore(4,10,"My");  
  10.         public static int time = 0;  
  11.         static void Main(string[] args)  
  12.         {  
  13.             for (int i = 0; i < 3; i++)  
  14.             {  
  15.                 Thread test = new Thread(new ParameterizedThreadStart(TestMethod));  
  16.  
  17.                 // 開始線程,并傳遞參數(shù) 
  18.                 test.Start(i);  
  19.             }  
  20.  
  21.             // 等待1秒讓所有線程開始并阻塞在信號(hào)量上 
  22.             Thread.Sleep(1000);  
  23.  
  24.             Console.Read();           
  25.         }  
  26.  
  27.         public static void TestMethod(object number)  
  28.         {  
  29.             // 設(shè)置一個(gè)時(shí)間間隔讓輸出有順序 
  30.             int span = Interlocked.Add(ref time, 500);  
  31.             Thread.Sleep(1000 + span);  
  32.  
  33.             //信號(hào)量計(jì)數(shù)減1 
  34.             semaphore.WaitOne();  
  35.               
  36.             Console.WriteLine("Thread {0} run ", number);  
  37.         }  
  38.     }  
 

運(yùn)行結(jié)果:[.Net線程處理系列]專題六:線程同步——信號(hào)量和互斥體

    從運(yùn)行結(jié)果中可以看出, 第二個(gè)進(jìn)程值運(yùn)行了一行語句, 因?yàn)槲覀冊(cè)O(shè)置的初始信號(hào)計(jì)數(shù)為4,每運(yùn)行一個(gè)線程,信號(hào)計(jì)數(shù)通過調(diào)用WaitOne方法減1,所以第二個(gè)進(jìn)行一開始信號(hào)計(jì)數(shù)為1而不是進(jìn)程一中的4,如果我們把信號(hào)計(jì)數(shù)后面的name參數(shù)去除的話,此時(shí)第二個(gè)進(jìn)程和第一個(gè)進(jìn)程中的結(jié)果應(yīng)該是一樣的(因?yàn)榇藭r(shí)沒有進(jìn)行不同進(jìn)程中線程的同步)。

二、互斥體(Mutex)

同樣互斥體也是同樣可以實(shí)現(xiàn)線程之間的同步和不同進(jìn)程中線程的同步的

先看看線程之間的同步的例子吧(在這里我也不多做解釋了,因?yàn)樗麄冎g的使用很類似,直接貼出代碼):

  1. class Program  
  2.     {  
  3.         public static Mutex mutex = new Mutex();  
  4.         public static int count;  
  5.  
  6.         static void Main(string[] args)  
  7.         {  
  8.             for (int i = 0; i < 10; i++)  
  9.             {  
  10.                 Thread test = new Thread(TestMethod);  
  11.  
  12.                 // 開始線程,并傳遞參數(shù) 
  13.                 test.Start();  
  14.             }  
  15.  
  16.             Console.Read();  
  17.         }  
  18.  
  19.         public static void TestMethod()  
  20.         {  
  21.             mutex.WaitOne();  
  22.             Thread.Sleep(500);  
  23.             count++;  
  24.             Console.WriteLine("Current Cout Number is {0}", count);  
  25.             mutex.ReleaseMutex();  
  26.         }  
  27.     } 
 
 

運(yùn)行結(jié)果:[.Net線程處理系列]專題六:線程同步——信號(hào)量和互斥體

 實(shí)現(xiàn)進(jìn)程間同步:

  1. class Program  
  2.     {  
  3.         public static Mutex mutex = new Mutex(false,"My");  
  4.  
  5.         static void Main(string[] args)  
  6.         {  
  7.             Thread t = new Thread(TestMethod);  
  8.             t.Start();  
  9.  
  10.             Console.Read();  
  11.         }  
  12.  
  13.         public static void TestMethod()  
  14.         {  
  15.             mutex.WaitOne();  
  16.             Thread.Sleep(5000);  
  17.             Console.WriteLine("Method start at : " + DateTime.Now.ToLongTimeString());  
  18.             mutex.ReleaseMutex();  
  19.         }  
  20.     } 
 
運(yùn)行結(jié)果:[.Net線程處理系列]專題六:線程同步——信號(hào)量和互斥體

    從運(yùn)行結(jié)果看出兩個(gè)進(jìn)程之間的時(shí)間間隔為5秒,當(dāng)我們把構(gòu)造函數(shù)中命名參數(shù)去掉時(shí)就可以看出差別了。


 三、小結(jié)

    到這里多線程處理基本上講完,這個(gè)系列也只是一個(gè)入門,真真要好好掌握多線程,還是要在項(xiàng)目中多去實(shí)戰(zhàn)的。接下來我可能會(huì)做一個(gè)小的例子的,大概的思路是實(shí)現(xiàn)一個(gè)文件的下載的這樣的例子。如果大家有什么好的例子來運(yùn)用多線程的知識(shí)的話,可以留言給我,我也會(huì)盡量去實(shí)現(xiàn)(如果不會(huì)的話,這樣也可以促使我去學(xué)習(xí)),實(shí)現(xiàn)后也會(huì)和大家分享的。

 

分享文章:[.Net線程處理系列]專題六:線程同步——信號(hào)量和互斥體
文章來源:http://muchs.cn/article18/ihsddp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)、響應(yīng)式網(wǎng)站企業(yè)網(wǎng)站制作、微信公眾號(hào)營(yíng)銷型網(wǎng)站建設(shè)、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計(jì)公司