c#多線程之間的排他鎖的實現(xiàn)
我們很多時候會碰到這樣的問題,使用多線程刷一個表的數(shù)據(jù)時需要多個線程不能重復(fù)提取數(shù)據(jù),那么這個時候就需要使用到線程的排他鎖了。
在c#里面其實很簡單,下面先來看一個簡單的小例子
Thread pingTask = new Thread(new ThreadStart(delegate { //從數(shù)據(jù)庫獲取1000條數(shù) var list = getdata(); })); //啟動線程 pingTask.Start();
如果這個時候我們開啟多個線程
代碼如下
for (int i = 0; i < 100; i++) { Thread pingTask = new Thread(new ThreadStart(delegate { //從數(shù)據(jù)庫獲取1000條數(shù) var list = getdata(); })); //啟動線程 pingTask.Start(); }
那么這100個線程獲取的數(shù)據(jù)可能大部分是重復(fù)的
怎么樣解決這個問題呢,兩種寫法
第一種寫法使用this
private List<company> getdata() { lock (this) { //提取數(shù)據(jù) return list; } }
這種寫法當(dāng)線程執(zhí)行到這一步時所有線程都會停止執(zhí)行,等待執(zhí)行完成
我們再來看第二種
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; } }
這種寫法只會鎖死這個方法,
同時只會有一個線程能執(zhí)行這個方法
大家可以根據(jù)自己的需求來使用
到此這篇關(guān)于c#多線程之間的排他鎖的實現(xiàn)的文章就介紹到這了,更多相關(guān)c#多線程排他鎖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#執(zhí)行表達(dá)式樹(Expression Tree)的具體使用
本文將深入探討表達(dá)式樹的基本概念、創(chuàng)建方法、修改和刪除節(jié)點、查詢和遍歷技巧以及在C#中的應(yīng)用示例,具有一定的參考價值,感興趣的可以了解一下2024-03-03