程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> C#多線程編程之應用ReaderWriterLock類完成多用戶讀與單用戶寫同步的辦法

C#多線程編程之應用ReaderWriterLock類完成多用戶讀與單用戶寫同步的辦法

編輯:C#入門知識

C#多線程編程之應用ReaderWriterLock類完成多用戶讀與單用戶寫同步的辦法。本站提示廣大學習愛好者:(C#多線程編程之應用ReaderWriterLock類完成多用戶讀與單用戶寫同步的辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是C#多線程編程之應用ReaderWriterLock類完成多用戶讀與單用戶寫同步的辦法正文


本文實例講述了C#多線程編程之應用ReaderWriterLock類完成多用戶讀與單用戶寫同步的辦法。分享給年夜家供年夜家參考,詳細以下:

摘要:C#供給了System.Threading.ReaderWriterLock類以順應多用戶讀/單用戶寫的場景。該類可完成以下功效:假如資本未被寫操作鎖定,那末任何線程都可對該資本停止讀操作鎖定,而且對讀操作鎖數目沒無限制,即多個線程可同時對該資本停止讀操作鎖定,以讀取數據。

應用Monitor或Mutex停止同步掌握的成績:因為獨有拜訪模子不許可任何情勢的並發拜訪,如許的效力老是不太高。很多時刻,運用法式在拜訪資本時是停止讀操作,寫操作絕對較少。為處理這一成績,C#供給了System.Threading.ReaderWriterLock類以順應多用戶讀/單用戶寫的場景。該類可完成以下功效:假如資本未被寫操作鎖定,那末任何線程都可對該資本停止讀操作鎖定,而且對讀操作鎖數目沒無限制,即多個線程可同時對該資本停止讀操作鎖定,以讀取數據。假如資本未被添加任何讀或寫操作鎖,那末一個且唯一一個線程可對該資本添加寫操作鎖定,以寫入數據。簡略的講就是:讀操作鎖是同享鎖,許可多個線程同時讀取數據;寫操作鎖是獨有鎖,統一時辰,僅許可一個線程停止寫操作。

示例代碼以下:

using System;
using System.Threading;
namespace ProcessTest
{
 class Program
 {
  //資本
  static int theResource = 0;
  //讀、寫操作鎖
  static ReaderWriterLock rwl = new ReaderWriterLock();
  static void Main(string[] args)
  {
   //分離創立2個讀操作線程,2個寫操作線程,並啟動
   Thread tr0 = new Thread(new ThreadStart(Read));
   Thread tr1 = new Thread(new ThreadStart(Read));
   Thread tr2 = new Thread(new ThreadStart(Write));
   Thread tr3 = new Thread(new ThreadStart(Write));
   tr0.Start();
   tr1.Start();
   tr2.Start();
   tr3.Start();
   //期待線程履行終了
   tr0.Join();
   tr1.Join();
   tr2.Join();
   tr3.Join();
   System.Console.ReadKey();
  }
  //讀數據
  static void Read()
  {
   for (int i = 0; i < 3; i++)
   {
    try
    {
     //請求讀操作鎖,假如在1000ms內未獲得讀操作鎖,則廢棄
     rwl.AcquireReaderLock(1000);
     Console.WriteLine("開端讀取數據,theResource = {0}", theResource);
     Thread.Sleep(10);
     Console.WriteLine("讀取數據停止,theResource = {0}", theResource);
     //釋放讀操作鎖
     rwl.ReleaseReaderLock();
    }
    catch (ApplicationException)
    {
     //獲得讀操作鎖掉敗的處置
    }
   }
  }
  //寫數據
  static void Write()
  {
   for (int i = 0; i < 3; i++)
   {
    try
    {
     //請求寫操作鎖,假如在1000ms內未獲得寫操作鎖,則廢棄
     rwl.AcquireWriterLock(1000);
     Console.WriteLine("開端寫數據,theResource = {0}", theResource);
     //將theResource加1
     theResource++;
     Thread.Sleep(100);
     Console.WriteLine("寫數據停止,theResource = {0}", theResource);
     //釋放寫操作鎖
     rwl.ReleaseWriterLock();
    }
    catch (ApplicationException)
    {
     //獲得寫操作鎖掉敗
    }
   }
  }
 }
}

上例平分別創立2個讀取線程和2個寫入線程,瓜代停止讀、寫操作。運轉成果以下圖:

不雅察運轉成果,我們很輕易看出:讀操作鎖是同享鎖,許可多個線程同時讀取數據;寫操作鎖是獨有鎖,僅許可一個線程停止寫操作。

假如一個線程在獲得讀操作鎖後,停止讀操作的途中,願望晉升鎖級別,將其變成寫操作鎖,可以挪用ReaderWriterLock類的UpgradeToWriterLock(int timeOut)辦法,該辦法前往一個LockCookie值,該值保留了UpgradeToWriterLock辦法挪用前哨程鎖的狀況。待寫操作完成後,可挪用DowngradeFromWriterLock(LockCookie lockcookie)辦法,該辦法依據傳入的LockCookie參數值,將線程鎖恢復到UpgradeToWriterLock辦法挪用前的狀況。詳細應用辦法,年夜家可以檢查MSDN以獲得相干示例。

願望本文所述對年夜家C#法式設計有所贊助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved