互斥量和临界区非常相似,只有拥有了互斥对象的线程才可以访问共享资源,而互斥对象只有一个,因此可以保证同一时刻有且仅有一个线程可以访问共享资源,达到线程同步的目的。

互斥量相对于临界区更为高级,可以对互斥量进行命名,支持跨进程的线程同步。互斥量是调用的Win32的API对互斥锁的操作,因此在同一操作系统下不同进程可以按照互斥锁的名称共享锁。

正因为如此,互斥锁的操作会更好资源,性能上相对于临界区也有降低,在使用时还要多斟酌。对于进程内的线程同步使用临界区性能会更佳。

在.Net中使用Mutex类来表示互斥量,使用实例的WaitOne()阻止线程执行至到获取Mutex对象,ReleaseMutex()释放锁资源,我们来看一下示例

class MutexTest
    {
        //创建Mutex对象
        private static Mutex mutex = new Mutex(true, "My");
        //
        static void Main(string[] args)
        {
            Run();
            Console.ReadLine();
        }
        //模拟多线程调用
        public static void Run()
        {
            const int count = 2;
            var threads = new Thread[count];
            for (var i = 0; i < count; i++)
            {
                var ts = new ThreadStart(UserResource);
                var t = new Thread(ts);
                t.Name = "thread" + (i + 1);
                threads[i] = t;
            }
            foreach (var t in threads)
            {
                t.Start();
            }
            //
            Console.WriteLine(string.Format("Creating thread {0} owns the Mutex.", Thread.CurrentThread.Name));
            Thread.Sleep(1000);
            mutex.ReleaseMutex();
            Console.WriteLine(string.Format("Creating thread {0} releases the Mutex.", Thread.CurrentThread.Name));
        }
        //修改共享资源值
        public static void UserResource()
        {
            mutex.WaitOne();
            Console.WriteLine(string.Format("Child thread named {0} owns the mutex.", Thread.CurrentThread.Name));
            Thread.Sleep(1000);
            mutex.ReleaseMutex();
            Console.WriteLine(string.Format("Child thread named {0} releases the mutex.", Thread.CurrentThread.Name));
        }
    }

Mutex对象是一个全局对象,构造时可以指定name,只要name一样都认为是同一个Mutext。另外再构造时指定的第一个Bool参数表示创建Mutex对象的线程是否拥有该互斥量。

如果是True表示拥有,必须要释放后才可以被其它线程使用。上述代码示例中就需要主线程释放Mutex。

首先由主线程创建一个Mutex对象,并拥有该Mutex对象

然后主线程接着执行,创建2个线程,线程内部使用WaitOne来阻止该线程继续执行,直到接收到Mutex对象释放的信号,方能获得Mutex使用权,继续执行。

Sleep 1秒之后,主线程释放Mutex对象

子线程WaitOne获得释放信号并抢占Mutex拥有权,获得者将进入执行资源代码,而另外的子现在要等到ReleaseMutex之后才能获得Mutex拥有权。

在使用Mutex时WaitOne用来阻止线程的执行,直到获取到Mutex对象的拥有权。也可以指定阻止时间,超时获取Mutex拥有权失败,会继续执行后续代码,执行完毕无需释放Mutex。

WaitOne要和ReleaseMutex成对使用,获取锁对象后要记得释放,否则会造成其它线程一直等待状态。

线程同步方式之互斥量Mutex的更多相关文章

  1. Linux的线程同步对象:互斥量Mutex,读写锁,条件变量

        进程是Linux资源分配的对象,Linux会为进程分配虚拟内存(4G)和文件句柄等 资源,是一个静态的概念.线程是CPU调度的对象,是一个动态的概念.一个进程之中至少包含有一个或者多个线程.这 ...

  2. Linux/Unix 线程同步技术之互斥量(1)

    众所周知,互斥量(mutex)是同步线程对共享资源访问的技术,用来防止下面这种情况:线程A试图访问某个共享资源时,线程B正在对其进行修改,从而造成资源状态不一致.与之相关的一个术语临界区(critic ...

  3. c# Thread5——线程同步之基本原子操作。Mutex互斥量的使用

    之前的博文也说到了如果多线程对于访问的公共资源操作都是原子操作,那么可以避免竞争条件.关于多线程的竞争可以百度. 1.执行最基本的原子操作 c#提供了一系列供我们使用的原子操作的方法和类型,比如我们的 ...

  4. 经典线程同步 互斥量Mutex

    阅读本篇之前推荐阅读以下姊妹篇: <秒杀多线程第四篇一个经典的多线程同步问题> <秒杀多线程第五篇经典线程同步关键段CS> <秒杀多线程第六篇经典线程同步事件Event& ...

  5. (转)经典线程同步 互斥量Mutex

    阅读本篇之前推荐阅读以下姊妹篇: <秒杀多线程第四篇一个经典的多线程同步问题> <秒杀多线程第五篇经典线程同步关键段CS> <秒杀多线程第六篇经典线程同步事件Event& ...

  6. 多线程面试题系列(7):经典线程同步 互斥量Mutex

    前面介绍了关键段CS.事件Event在经典线程同步问题中的使用.本篇介绍用互斥量Mutex来解决这个问题. 互斥量也是一个内核对象,它用来确保一个线程独占一个资源的访问.互斥量与关键段的行为非常相似, ...

  7. 秒杀多线程第七篇 经典线程同步 互斥量Mutex

    本文转载于:http://blog.csdn.net/morewindows/article/details/7470936 前面介绍了关键段CS.事件Event在经典线程同步问题中的使用.本篇介绍用 ...

  8. 转--- 秒杀多线程第七篇 经典线程同步 互斥量Mutex

    阅读本篇之前推荐阅读以下姊妹篇: <秒杀多线程第四篇一个经典的多线程同步问题> <秒杀多线程第五篇经典线程同步关键段CS> <秒杀多线程第六篇经典线程同步事件Event& ...

  9. [一个经典的多线程同步问题]解决方案三:互斥量Mutex

    本篇通过互斥量来解决线程的同步,学习其中的一些知识. 互斥量也是一个内核对象,它用来确保一个线程独占一个资源的访问.互斥量与关键段的行为非常相似,并且互斥量可以用于不同进程中的线程互斥访问资源.使用互 ...

随机推荐

  1. 【转】GDI+中发生一般性错误的解决办法

    今天在开发.net引用程序中,需要System.Drawing.Image.Save 创建图片,debug的时候程序一切正常,可是发布到IIS后缺提示出现“GDI+中发生一般性错误”的异常. 于是开始 ...

  2. MVC会员注册

    自从写了<数据库数据加密与解密>http://www.cnblogs.com/insus/p/3434735.html.其中也有提及Insus.NET将要在MVC应用程序中实现会员注册的功 ...

  3. Fork/Join 框架-设计与实现(翻译自论文《A Java Fork/Join Framework》原作者 Doug Lea)

    作者简介 Dong Lea任职于纽约州立大学奥斯威戈分校(State University of New York at Oswego),他发布了第一个广泛使用的java collections框架实 ...

  4. Spring Cloud学习笔记--Spring Boot初次搭建

    1. Spring Boot简介 初次接触Spring的时候,我感觉这是一个很难接触的框架,因为其庞杂的配置文件,我最不喜欢的就是xml文件,这种文件的可读性很不好.所以很久以来我的Spring学习都 ...

  5. POJ1149(最大流)

    PIGS Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 21678   Accepted: 9911 Description ...

  6. 解决Python 爬取ssh证书 的报错问题

    Python3 中会要求添加信任证书,但只是进行爬取数据就没必要了,我们可以忽略它 r1 =requests.get("https://www.baidu.com", verify ...

  7. 语义SLAM的数据关联和语义定位(一)

    语义SLAM和多传感器融合是自动驾驶建图和定位部分比较热门的两种技术.语义SLAM中,语义信息的数据关联相较于特征点的数据关联有所不同.我们一般用特征描述子的相似性来匹配和关联不同图像中的特征点.特征 ...

  8. dcloud资源升级方式更新app

    var wgtVer = null; plus.runtime.getProperty(plus.runtime.appid, function(inf) { wgtVer = inf.version ...

  9. Group by 分组查询 实战

    实战经历,由于本人在共享单车上班,我们的单车管理模块,可以根据单车号查询单车,但是单车号没有设置unique(独一无二约束),说以这就增加了单车号可能重复的风险,但是一般情况下,单车号是不会重复的,因 ...

  10. 蓝魔i7s刷机

    ,电脑管家,豌豆荚之类的PC工具 5. 安装MFT6.0.43.exe, 注意:MFT6.0.43需要对应的ISOC和USB驱动,不可使用其它版本 6. 将CUSTOM_CONFIG..INI文件复制 ...