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#法式設計有所贊助。