我是靠谱客的博主 矮小小馒头,最近开发中收集的这篇文章主要介绍C#中Mutex的用法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

C#中Mutex是互斥锁,位于System.Threading 命名空间中。

顾名思义,它是一个互斥的对象,同一时间只有一个线程可以拥有它,该类还可用于进程间同步的同步基元。

如果当前有一个线程拥有它,在没有释放之前,其它线程是没有权利拥有它的。我们可以把Mutex看作洗手间,上厕所的人看作线程;上厕所的人先进洗手间,拥有使用权,上完厕所之后出来,把洗手间释放,其他人才可以使用。

线程使用Mutex.WaitOne()方法等待C# Mutex对象被释放,如果它等待的C# Mutex对象被释放了,它就自动拥有这个对象,直到它调用Mutex.ReleaseMutex()方法释放这个对象,而在此期间,其他想要获取这个C# Mutex对象的线程都只有等待。

我们可以利用这个特性来控制一个应用程序只能运行一个实例。其他实例由于得不到这个Mutex而不能运行。

代码如下所示

 

private static Mutex s_Mutex = new Mutex();
//互斥锁
public virtual bool RaiseSource(SourceParameter source, int MPluse = 1)
{
s_Mutex.WaitOne();
try
{
short iPhaseFlag = GetPhaseFlag(source.MeterPhaseWire, source.WattVar);
int iCount = 0;
do
{
try
{
string phaseStr = GetPhaseStr(source.Phase);
if (true == HSCOMWrp.Adjust_UI1(
iPhaseFlag,
source.RatingVoltage,
source.RatingCurrent,
source.StandMeterFrequency,
(short)source.PhaseOrder,
(short)source.Direct,
source.Volt_PerA,
//实际电压比率
source.Volt_PerB,
source.Volt_PerC,
source.Curr_PerA,
//实际电流比率
phaseStr,
source.FactorStr,
this.m_CalibratorParameter.StandardMeterType,
Dev_Port
))
{
//当调用返回后源是稳定的吧?要么延迟少点(2-3秒即可)?
System.Threading.Thread.Sleep(this.m_CalibratorParameter.SteadyTime * 1000);
return true;
}
}
catch
{
System.Threading.Thread.Sleep(RETRY_DELAY_TIME);
}
System.Threading.Thread.Sleep(RETRY_DELAY_TIME);
iCount++;
} while (iCount < RETRY_NUMBERS);
return false;
}
finally
{
s_Mutex.ReleaseMutex();
}
}

此外还需说明一点,mutex的name是在系统中是唯一的,也就是上述代码中的Name,系统依靠这个name属性来标识唯一的Mutex。

最后

以上就是矮小小馒头为你收集整理的C#中Mutex的用法的全部内容,希望文章能够帮你解决C#中Mutex的用法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部