. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->自由讨论区
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  繁忙等待法(busy waiting)该怎么实现  [待解决] 回复[ 0次 ]   点击[ 185次 ]  
grc10010010
[帖 主]   [ 发表时间:2012-09-06 08:38 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:13
注册日期:2011-07-13 08:38
有2个任务(编号为0和1)互斥机制的代码如下:

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

Enter_Critical_Section(int my_tast_id,int other_task_id)
{
    while (flag[other_task_id] == TURE);
    flag[my_task_id] = TRUE;
}

Exit_Critical_Section(int my_task_id,int other_task_id)
{
    flag[my_task_id] = FALSE;
}

当一个任务要访问临界资源时,可以调用上述2个函数,比如任务0的代码可以如下:

Enter_Critical_Section(0,1);
...使用该资源...
Exit_Critical_Section(0,1);
...做其它事情...

如果是任务1要访问临界资源,代码是不是改成这样:

Enter_Critical_Section(1,0);
...使用该资源...
Exit_Critical_Section(1,0);
...做其它事情...
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved