用信号量描述前趋图

1)声明有向边个数个信号量,并把它们初始化为0。每个信号量代表一条有向边。
2)声明结点个数个进程。每个进程包含对应结点代表的任务。
对于每个进程中的任务结点,如果它有直接前趋,就对所有代表直接前趋的信号量执行p操作,并且这些p操作在结点任务之前执行。
如果它有直接后继,就对所有代表直接后继的信号量执行v操作,并且这些v操作在结点任务之后执行。
3)并发执行这些进程。

例:

在这里插入图片描述
伪代码


semaphere a,b,c,d,e,f,g;
//定义进程P1,用于执行s1操作
P1(){ s1(); v(a); v(b); }
//定义进程P2,用于执行s2操作
P2(){ p(a); s2(); v(c); v(d); }
//定义进程P3,用于执行s3操作
P3(){ p(b); s3(); v(e); }
//定义进程P4,用于执行s4操作
P4(){ p(c); s4(); v(f); }
//定义进程P5,用于执行s5操作
P5(){ p(d); s5(); v(g); }
//定义进程P6,用于执行s6操作
P6(){ p(e); p(g); p(f); s6(); }

main(){
a=b=c=d=e=f=g=0;
a=0,b=0,c=0,d=0,e=0,f=0,g=0;
cobegin //并发执行进程
	P1(); P2(); P3(); P4(); P5(); P6();
eoend
}

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值