lock,顧名思義,鎖。
lock的用法說起來容易,就是鎖定當前正在執行的內容。真正理解卻不容易。
於是,我做了下面的測試,對比使用lock和不使用lock的情況,才真正理解了。
在下面的代碼中,線程1,2同時調用函數write(),執行函數里面的內容。
使用線程鎖lock的時候,不會出現兩個線程搶占執行函數的情況;
不使用線程鎖lock的時候,出現兩個線程鎖搶占執行函數的情景。
所以在有很多個線程(Thread 對象)同時運行,要執行同一個操作(調用一個函數)的時候,使用lock把代碼鎖定,就告訴那很多個線程:本函數的本內容只能在同一時間被一個線程調用!
也就避免了第二個代碼里競爭運行的結果。
另外,lock一般出現在while(true)循環里。在有線程要調用的函數里面出現。
使用lock的情況如下:
class Program { static Object locker = new object(); //創建鎖對象 public static int money = 0; //捐款總額 static void Main(string[] args) { Thread th1 = new Thread(write); //第一個線程 Thread th2 = new Thread(write); //第二個線程 th1.Start(); //同時開啟,並行進行 th2.Start(); } private static void write() { while (true) { lock (locker) { money = money + 100; Console.WriteLine("前面的人正在投幣,后面的人請等待..."); Thread.Sleep(3000); Console.WriteLine("目前共募捐:"+ money+"元\n"); } } } }
輸出的結果:非常規整,就像只有一個線程運行的結果一樣。
不使用lock的情況(把lock注釋掉了):th1和th2競爭占用要執行的同一個資源。
class Program { static Object locker = new object(); //創建鎖對象 public static int money = 0; //捐款總額 static void Main(string[] args) { Thread th1 = new Thread(write); //第一個線程 Thread th2 = new Thread(write); //第二個線程 th1.Start(); //同時開啟,並行進行 th2.Start(); } private static void write() { while (true) { //lock (locker) //{ money = money + 100; Console.WriteLine("前面的人正在投幣,后面的人請等待..."); Thread.Sleep(3000); Console.WriteLine("目前共募捐:"+ money+"元\n"); //} } } }
結果出現兩個線程同時搶占函數,同時使用資源的情況。
轉原文鏈接:https://blog.csdn.net/qq_38628970/article/details/104696940?spm=1035.2023.3001.6557&utm_medium=distribute.pc_relevant_bbs_down.none-task-blog-2~default~OPENSEARCH~default-6.nonecase&depth_1-utm_source=distribute.pc_relevant_bbs_down.none-task-blog-2~default~OPENSEARCH~default-6.nonecase