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