Mutex对象使用时发现的问题

Mutex对象使用时发现的问题Mutex对象等待互斥对象的方法有:Mutex.WaitAll、WaitOne、Mutex.WaitAny使用Mutex对象经常出现的异常现象有:异常一、 由于出现被放弃的mutex,等待过程结束原因:获取互斥对象后没有显式的释放对应的互斥对象就结束了对应的线程解决办法:每调用一个等待方法,在结束调用时都要调用ReleaseMutex()方法进行Mutex对象释放。而每种释

大家好,又见面了,我是你们的朋友全栈君。

Mutex对象等待互斥对象的方法有:Mutex.WaitAll、WaitOne、Mutex.WaitAny

使用Mutex对象经常出现的异常现象有:

异常一、  由于出现被放弃的 mutex,等待过程结束

原因:获取互斥对象后没有显式的释放对应的互斥对象就结束了对应的线程

解决办法:每调用一个等待方法,在结束调用时都要调用ReleaseMutex()方法进行Mutex对象释放。而每种释放的方法方式也有点区别。如:

(1)、WaitOne()

Mutex gM1=new Mutex();

gM1.WaitOne();//等待gM1的释放

gM1的释放为:

gM1.ReleaseMutex();

(2)、WaitAll()

Mutex[] gMs = new Mutex[2];

gMs[0] = gM1;

gMs[1] = gM2;

Mutex.WaitAll(gMs); //等待gM1和gM2的释放

for (int i = 0; i < gMs.Length; i++)

{

gMs[0].ReleaseMutex();

}

(3)、WaitAny()

Mutex[] gMs = new Mutex[2];

gMs[0] = gM1;

gMs[1] = gM2;

int index = Mutex.WaitAny(gMs); //等待数组中任意一个Mutex对象被释放

gMs[index].ReleaseMutex();

异常二  从不同步的代码块中调用了对象同步方法。

此问题是在调用 WaitAny()方法后调用多个释放对象导致的。如:

Mutex[] gMs = new Mutex[2];

gMs[0] = gM1;

gMs[1] = gM2;

Mutex.WaitAny(gMs);

gM1.ReleaseMutex();

gM2.ReleaseMutex();

正确的写法如:

Mutex[] gMs = new Mutex[2];

gMs[0] = gM1;

gMs[1] = gM2;

int index = Mutex.WaitAny(gMs); //等待数组中任意一个Mutex对象被释放

gMs[index].ReleaseMutex();

 

总结:调用Mutex对象的等待与释放方法要成对出现,调用哪个就要释放哪个。

写的有点俗,请见谅哈

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/153203.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • jupyter和python的关系_jupyter notebook和python

    jupyter和python的关系_jupyter notebook和python这个问题参见以下文章即可,讲的很全面。核心总结Python就是原生python;anaconda类似第三方集成,方便我们管理,而且自带很多库。如果选择安装Python的话,那么还需要pipinstall一个一个安装各种库,安装起来比较痛苦,还需要考虑兼容性;PyCharm就是一个IDE的角色,和NotePad没什么本质区别。只是大家习惯上,java配合MyEclipse使用,Anaconda…

    2022年8月27日
    11
  • 二叉排序树(二)

    二叉排序树(二)

    2021年8月24日
    46
  • 用docker部署jar包_docker run 参数

    用docker部署jar包_docker run 参数小小总结一、思路1、将docker容器中的指定文件夹挂载到宿主机上,更新jar包只需上传到宿主机指定路径,方便更新2、利用bash文件运行jar包,并构建该bash的镜像,代替构建直接运行jar包的镜像,利于镜像与jar包解耦。例如,app-1.0.0.jar升级到app-2.0.0.jar,只须更改bash文件的内容,而无须构建新的镜像。二、准备工作1、创建存放docker配置文件、jar包的文件夹在宿主机上,创建文件夹:/home/admin/app,用于存放bash文件和jar包。然

    2022年9月27日
    2
  • 关于错误“将截断字符串或二进制数据。 语句已终止”「建议收藏」

    关于错误“将截断字符串或二进制数据。 语句已终止”「建议收藏」解决:   数据库的字符长度

    2022年10月7日
    2
  • 解决: Linux – git: command not found

    解决: Linux – git: command not found出错原因:服务器没有安装GIT,所以导致出错。解决方法:Centos下使用:yuminstallgit-y或者yuminstall-ygitUbuntu/Debian下使用:apt-getinstallgit-y转自:https://my.oschina.net/u/1382365/blog/490262?p=1…

    2022年5月7日
    43
  • TCP拥塞控制策略

    TCP拥塞控制策略一、Reno1、算法执行示意                                   图1 算法执行图2、算法原理Reno是一种基于丢包的拥塞控制算法,将丢包视为出现拥塞,采取缓慢探测的方式,逐渐增大拥塞窗口,当出现丢包时,将拥塞窗口减小。该算法拥塞控制的过程分为四个阶段:慢开始、拥塞避免、快重传和快恢复,分别对应四种算法。 (1)慢开始算法当主机总数…

    2022年6月24日
    28

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号