概述
我们很多时候会碰到这样的问题,使用多线程刷一个表的数据时需要多个线程不能重复提取数据,那么这个时候就需要使用到线程的排他锁了。
在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#多线程排他锁内容请搜索靠谱客以前的文章或继续浏览下面的相关文章希望大家以后多多支持靠谱客!
最后
以上就是真实大雁为你收集整理的c#多线程之间的排他锁的实现的全部内容,希望文章能够帮你解决c#多线程之间的排他锁的实现所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复