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 getdata()
        {
            lock (this)
            {
//提取数据
 
                return list;
            }
        }

这种写法当线程执行到这一步时所有线程都会停止执行,等待执行完成

我们再来看第二种

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

这种写法只会锁死这个方法,
同时只会有一个线程能执行这个方法
大家可以根据自己的需求来使用

到此这篇关于c#多线程之间的排他锁的实现的文章就介绍到这了,更多相关c#多线程排他锁内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(c#多线程之间的排他锁的实现)