实验三:同步问题
安全1601 16281221 邓子轩
- 通过fork的方式,产生4个进程P1,P2,P3,P4,每个进程打印输出自己的名字,例如P1输出“I am the process P1”。要求P1最先执行,P2、P3互斥执行,P4最后执行。通过多次测试验证实现是否正确。
代码如下:
按照要求建立的的四个进程的前趋图如下:
在代码中通过信号量P23_signal来实现P2与P3的互斥关系,当P1执行完毕后为P23_signal增加一个可用资源,之后P2跟P3竞争,取得信号量的进程将消耗掉这个资源,执行完毕后则释放一个资源,则另一个进程得以执行。
P2_signal、P3_signal初值为0,当P2、P3均执行完毕后,二者资源值才均为1。P4进程通过wait操作等待两个进程(P2、P3)的结束。
运行结果如下:
- 火车票余票数ticketCount 初始值为1000,有一个售票线程,一个退票线程,各循环执行多次。添加同步机制,使得结果始终正确。要求多次测试添加同步机制前后的实验效果。(说明:为了更容易产生并发错误,可以在适当的位置增加一些pthread_yield(),放弃CPU,并强制线程频繁切换,例如售票线程的关键代码:
temp=ticketCount;
pthread_yield();
temp=temp-1;
pthread_yield();
ticketCount=temp;
退票线程的关键代码:
temp=ticketCount;
pthread_yield();
temp=temp+