c#多線程之間的排他鎖的實(shí)現(xiàn)
我們很多時(shí)候會(huì)碰到這樣的問題,使用多線程刷一個(gè)表的數(shù)據(jù)時(shí)需要多個(gè)線程不能重復(fù)提取數(shù)據(jù),那么這個(gè)時(shí)候就需要使用到線程的排他鎖了。
在c#里面其實(shí)很簡(jiǎn)單,下面先來看一個(gè)簡(jiǎn)單的小例子
Thread pingTask = new Thread(new ThreadStart(delegate
{
//從數(shù)據(jù)庫(kù)獲取1000條數(shù)
var list = getdata();
}));
//啟動(dòng)線程
pingTask.Start();
如果這個(gè)時(shí)候我們開啟多個(gè)線程
代碼如下
for (int i = 0; i < 100; i++)
{
Thread pingTask = new Thread(new ThreadStart(delegate
{
//從數(shù)據(jù)庫(kù)獲取1000條數(shù)
var list = getdata();
}));
//啟動(dòng)線程
pingTask.Start();
}
那么這100個(gè)線程獲取的數(shù)據(jù)可能大部分是重復(fù)的
怎么樣解決這個(gè)問題呢,兩種寫法
第一種寫法使用this
private List<company> getdata()
{
lock (this)
{
//提取數(shù)據(jù)
return list;
}
}
這種寫法當(dāng)線程執(zhí)行到這一步時(shí)所有線程都會(huì)停止執(zhí)行,等待執(zhí)行完成
我們?cè)賮砜吹诙N
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;
}
}
這種寫法只會(huì)鎖死這個(gè)方法,
同時(shí)只會(huì)有一個(gè)線程能執(zhí)行這個(gè)方法
大家可以根據(jù)自己的需求來使用
到此這篇關(guān)于c#多線程之間的排他鎖的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)c#多線程排他鎖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C#多線程中的互斥鎖Mutex
- C#多線程死鎖介紹與案例代碼
- C#在復(fù)雜多線程環(huán)境下使用讀寫鎖同步寫入文件
- C#使用讀寫鎖解決多線程并發(fā)問題
- C#多線程系列之讀寫鎖
- C#多線程系列之多線程鎖lock和Monitor
- C#筆試題之同線程Lock語(yǔ)句遞歸不會(huì)死鎖
- C#多線程中如何運(yùn)用互斥鎖Mutex
- C#使用讀寫鎖三行代碼簡(jiǎn)單解決多線程并發(fā)的問題
- C#多線程編程中的鎖系統(tǒng)(四):自旋鎖
- C#多線程編程中的鎖系統(tǒng)(三)
- C#多線程編程中的鎖系統(tǒng)(二)
- C#多線程編程中的鎖系統(tǒng)基本用法
- C#多線程之線程鎖
相關(guān)文章
C#實(shí)現(xiàn)一個(gè)控制臺(tái)的點(diǎn)餐系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)一個(gè)控制臺(tái)的點(diǎn)餐系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11
C#執(zhí)行表達(dá)式樹(Expression Tree)的具體使用
本文將深入探討表達(dá)式樹的基本概念、創(chuàng)建方法、修改和刪除節(jié)點(diǎn)、查詢和遍歷技巧以及在C#中的應(yīng)用示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03

