這篇文章將為大家詳細講解有關C# 中l(wèi)ock關鍵字的作用是什么,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供恭城網站建設、恭城做網站、恭城網站設計、恭城網站制作等企業(yè)網站建設、網頁設計與制作、恭城企業(yè)網站模板建站服務,10余年恭城做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。
C#提供了一個關鍵字lock,它可以把一段代碼定義為互斥段(critical section),互斥段在一個時刻內只允許一個線程進入執(zhí)行,而其他線程必須等待。在C# lock關鍵字定義如下:
lock(expression) statement_block
expression代表你希望跟蹤的對象,通常是對象引用。
如果你想保護一個類的實例,一般地,你可以使用this;如果你想保護一個靜態(tài)變量(如互斥代碼段在一個靜態(tài)方法內部),一般使用類名就可以了。
而statement_block就是互斥段的代碼,這段代碼在一個時刻內只可能被一個線程執(zhí)行。
下面是一個使用C# lock關鍵字的典型例子,在注釋里說明了C# lock關鍵字的用法和用途。
示例如下:
usingSystem; usingSystem.Threading; namespaceThreadSimple { internalclassAccount { intbalance; Randomr=newRandom(); internalAccount(intinitial) { balance=initial; } internalintWithdraw(intamount) { if(balance<0) { //如果balance小于0則拋出異常 thrownewException("NegativeBalance"); } //下面的代碼保證在當前線程修改balance的值完成之前 //不會有其他線程也執(zhí)行這段代碼來修改balance的值 //因此,balance的值是不可能小于0的 lock(this) { Console.WriteLine("CurrentThread:"+Thread.CurrentThread.Name); //如果沒有l(wèi)ock關鍵字的保護,那么可能在執(zhí)行完if的條件判斷之后 //另外一個線程卻執(zhí)行了balancebalance=balance-amount修改了balance的值 //而這個修改對這個線程是不可見的,所以可能導致這時if的條件已經不成立了 //但是,這個線程卻繼續(xù)執(zhí)行balancebalance=balance-amount,所以導致balance可能小于0 if(balance>=amount) { Thread.Sleep(5); balancebalance=balance-amount; returnamount; } else { return0;//transactionrejected } } } internalvoidDoTransactions() { for(inti=0;i<100;i++) Withdraw(r.Next(-50,100)); } } internalclassTest { staticinternalThread[]threads=newThread[10]; publicstaticvoidMain() { Accountacc=newAccount(0); for(inti=0;i<10;i++) { Threadt=newThread(newThreadStart(acc.DoTransactions)); threads[i]=t; } for(inti=0;i<10;i++) threads[i].Name=i.ToString(); for(inti=0;i<10;i++) threads[i].Start(); Console.ReadLine(); } } }
關于C# 中l(wèi)ock關鍵字的作用是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。