c#多線程之間的排他鎖的實現

我們很多時候會碰到這樣的問題,使用多線程刷一個表的數據時需要多個線程不能重復提取數據,那麼這個時候就需要使用到線程的排他鎖瞭。

在c#裡面其實很簡單,下面先來看一個簡單的小例子

Thread pingTask = new Thread(new ThreadStart(delegate
           {
               //從數據庫獲取1000條數
               var list = getdata();
           }));
 
           //啟動線程
           pingTask.Start();

如果這個時候我們開啟多個線程

代碼如下

for (int i = 0; i < 100; i++)
            {
                Thread pingTask = new Thread(new ThreadStart(delegate
               {
                //從數據庫獲取1000條數
                var list = getdata();
               }));
 
                //啟動線程
                pingTask.Start(); 
            }

那麼這100個線程獲取的數據可能大部分是重復的
怎麼樣解決這個問題呢,兩種寫法

第一種寫法使用this

private List<company> getdata()
        {
            lock (this)
            {
//提取數據
 
                return list;
            }
        }

這種寫法當線程執行到這一步時所有線程都會停止執行,等待執行完成

我們再來看第二種

object obj=new object()
       private List<company> getdata()
       {
           lock (obj)
           {
               List<ckb_com> list = ckbbll.FindList($" com_id >={index} and com_id<{index + pagesize}");
               index = index + pagesize;
 
               return list;
           }
       }

這種寫法隻會鎖死這個方法,
同時隻會有一個線程能執行這個方法
大傢可以根據自己的需求來使用

到此這篇關於c#多線程之間的排他鎖的實現的文章就介紹到這瞭,更多相關c#多線程排他鎖內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: