双标志先检查法

本文讨论了双标志先检查法作为临界区互斥的一种软件实现方式,分析了为何该方法无法确保资源互斥访问,并通过一个例子解释了原因在于Enter_Critical_Section()函数执行的非原子性。此外,还探讨了将函数中两条语句互换位置后可能导致的死锁问题。
摘要由CSDN通过智能技术生成

【知识回顾】

临界区互斥(软件方法)

基本思想:进程通过while循环判断对方的FLAG是否为true(是true则死循环);若用完临界区后则修改自己的FLAG

典例】假设有2个线程(编号为0和1)需要去访问同一个共享资源,为避免竞争状态的问题,必须实现一种互斥机制,使得在任何时候只能有一个线程访问这个资源,假设有如下一段代码:

Bool flag[2];//flag数组,初始化为FALSE

Enter_Critical_Section(int my_thread_id,int other_thread_id){
    While(flag[other_thread_id]==TRUE);//空循环语句
    Flag[my_thread_id]=TRUE;
}

Exit_Critical_Section(int my_thread_id,int other_thread_id){
    flag[my_thread_id]=FALSE;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山顶夕景

小哥哥给我买个零食可好

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值