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!