PV操作经典例题——司机与售票员的进程同步问题

例1:

  • 司机的活动: 启动车辆, 正常行车, 到站停车。
  • 售票员活动: 关车门, 售票, 开车门。

注意:当发车时间到,售票员关好车门后,司机才能启动车辆,售票员才开始售票。
当到站时,司机停稳车后,售票员才能打开车门,车上乘客先下车,然后站牌乘客上车,用PV模拟售票员和汽车司机的同步行为。
解析:在这个问题中没有资源的抢夺,所以无互斥信号量。司机和售票员是同步关系,司机需要接收门是否关好的信号量,而售票员需要接收车是否到站的信号量。
活动顺序:关车门->启动车辆->售票->到站停车->开车门
初始状态为:停车且门未关。
流程:售票员给司机关门的信号,司机收到后开始正常行驶车辆,到站时由司机给售票员停车的信号。
解:设关门信号量为door=0,停车信号量为stop=0。

void conductor()
{
	while(true)
	{
		//关门
		signal(door);//售票员给司机关门的信号
		//此阶段为售票时间
		wait(stop);//等待停车信号,一旦停车,则开门
		//开门
	}
}
void driver()
{
	while(true)
	{
		wait(door);//司机等待关门信号,一旦获取信号,则启动车辆
		//此阶段为正常行车时间
		signal(stop);//司机给售票员停车的信号
	}
}

例2:若有两个售票员,一人控制一扇门,其余情况不变。用PV模拟售票员和汽车司机的同步行为。
设两扇门的信号量为door1,door2;司机与两位售票员都需要通信,告知他们停车的信号,将其设为stop1和stop2。
解:设door1=0,door2=0,stop1=0,stop2=0;

void conductor1()
{
	while(true)
	{
		//关门
		signal(door1);//售票员给司机关门的信号
		//此阶段为售票时间
		wait(stop1);//等待停车信号,一旦停车,则开门
		//开门
	}
}
void conductor2()
{
	while(true)
	{
		//关门
		signal(door2);//售票员给司机关门的信号
		//此阶段为售票时间
		wait(stop2);//等待停车信号,一旦停车,则开门
		//开门
	}
}
void driver()
{
	while(true)
	{
		wait(door1);
		wait(door2);//司机等待两扇门的关门信号,一旦获取信号,则启动车辆
		//此阶段为正常行车时间
		signal(stop1);//司机给售票员1停车的信号
		signal(stop2);//司机给售票员2停车的信号
	}
}

你可能感兴趣的:(操作系统)