C3多线程并发--锁--Mutex

2024-06-19 00:48
文章标签 并发 多线程 c3 mutex

本文主要是介绍C3多线程并发--锁--Mutex,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

定义:
Mutex跨多个线程同步访问的类。只有一个线程能获得互斥锁定,访问受互斥保护的同步代码区域。
说明:
在Mutex类的构造函数中,可以指定互斥是否最初应由主调线程拥有,定义互斥的名称,获得互斥是否已存在的信息。
实例如下:
//引用命名空间
using System.Threading;

bool flag = false;
Mutex mutex = new Mutex(false, “MainForm”, out flag);
其中:
第一个参数:指定互斥是否最初应由主调线程拥有。
第二个参数:MainForm为互斥量的名字,操作系统中只有一个命名为MainForm的互斥量的mutex,如果一个线程得到这个MainForm的互斥锁,其他线程就无法得到这个互斥锁了,必须等待那个线程对这个进程释放。
第三个参数:定义为输出参数,接收一个表示互斥是否为新建的布尔值。如果返回的值是false,就表示互斥已经定义,互斥可以在另一个进程中定义,因为操作系统能够识别有名称的互斥,它由不同的进程共享。如果没有给互斥指定名称,互斥就是未命名的,不在不同的进程之间共享。

实例:

using System;
using System.Threading;
using System.Windows.Forms;namespace 互斥锁
{public partial class Form1 : Form{public Form1(){InitializeComponent();#region 只能运行一个程序bool flag = false;Mutex mutex = new Mutex(true, "Test", out flag);//第一个参数:true--给调用线程赋予互斥体的初始所属权//第二个参数:互斥体的名称//第三个参数:返回值,如果调用线程已被授予互斥体的初始所属权,则返回trueif (!flag){MessageBox.Show("程序已运行!", "确定", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);Environment.Exit(1);//退出程序}#endregion}}
}

说明:

调用Mutex类的WaitOne()方法获得互斥锁定,调用Mutex类的ReleaseMutex()方法释放互斥锁定。Mutex类与Monitor类类似,每次只有一个线程能拥有互斥锁定,这意味着,每次只有一个线程能访问受互斥保护的临界资源。Mutex类与Monitor类的不同之处是:Mutex类提供了跨多个进程同步访问的功能,在Mutex类的构造函数中可以为互斥指定名称,命名的互斥可以被不同的进程共享,因为操作系统能够识别有名称的互斥;如果没有给互斥指定名称,互斥就是未命名的,在不同的进程之间不能共享,只能在一个进程内起作用。本文实例使用的是未命名的互斥,对进程内的线程进行同步。

实例:

/*以下代码模拟“从自动取款机中取钱”的操作:当账户余额大于等于1000时,取出1000放入口袋。
代码中使用两个线程同时执行取钱操作,若不进行同步处理,可能会存在两个线程同时进入取钱
逻辑,导致最终取出2000的错误结果。所以代码中使用Mutex类同步线程访问取钱逻辑
(临界资源)。*/
using System;
using System.Threading;
namespace MutexExample
{class Program{private static Mutex mutex = new Mutex();public static int account = 1000;//账户public static int pocket = 0;//口袋static void Main(string[] args){Thread t1 = new Thread(DoWork);t1.Start();Thread t2 = new Thread(DoWork);t2.Start();t1.Join();t2.Join();Console.WriteLine("pocket=" + pocket);}public static void DoWork(){if (mutex.WaitOne()){try{if (account >= 1000){Thread.Sleep(1000);//自动取款机打了个小盹account -= 1000;pocket += 1000;}}finally{mutex.ReleaseMutex();}}}}
}

这篇关于C3多线程并发--锁--Mutex的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1073534

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

MySQL中处理数据的并发一致性的实现示例

《MySQL中处理数据的并发一致性的实现示例》在MySQL中处理数据的并发一致性是确保多个用户或应用程序同时访问和修改数据库时,不会导致数据冲突、数据丢失或数据不一致,MySQL通过事务和锁机制来管理... 目录一、事务(Transactions)1. 事务控制语句二、锁(Locks)1. 锁类型2. 锁粒

深入解析Java NIO在高并发场景下的性能优化实践指南

《深入解析JavaNIO在高并发场景下的性能优化实践指南》随着互联网业务不断演进,对高并发、低延时网络服务的需求日益增长,本文将深入解析JavaNIO在高并发场景下的性能优化方法,希望对大家有所帮助... 目录简介一、技术背景与应用场景二、核心原理深入分析2.1 Selector多路复用2.2 Buffer

Qt中实现多线程导出数据功能的四种方式小结

《Qt中实现多线程导出数据功能的四种方式小结》在以往的项目开发中,在很多地方用到了多线程,本文将记录下在Qt开发中用到的多线程技术实现方法,以导出指定范围的数字到txt文件为例,展示多线程不同的实现方... 目录前言导出文件的示例工具类QThreadQObject的moveToThread方法实现多线程QC

Go语言使用sync.Mutex实现资源加锁

《Go语言使用sync.Mutex实现资源加锁》数据共享是一把双刃剑,Go语言为我们提供了sync.Mutex,一种最基础也是最常用的加锁方式,用于保证在任意时刻只有一个goroutine能访问共享... 目录一、什么是 Mutex二、为什么需要加锁三、实战案例:并发安全的计数器1. 未加锁示例(存在竞态)

RabbitMQ消费端单线程与多线程案例讲解

《RabbitMQ消费端单线程与多线程案例讲解》文章解析RabbitMQ消费端单线程与多线程处理机制,说明concurrency控制消费者数量,max-concurrency控制最大线程数,prefe... 目录 一、基础概念详细解释:举个例子:✅ 单消费者 + 单线程消费❌ 单消费者 + 多线程消费❌ 多