先来看看例题
这是上次在共享内存那里提过的题目,我们说到之前解决存在的问题,这次来改进。那好嘛!先看看题目,我们考虑需要几个信号量,同时他们的初值又分别是多少,再写出代码。
如何考虑,定义几个信号量和确定初值呢?
以下代码中前两个是为定义信号量的,后两个是在上次共享内存那里的代码中加入了信号量的控制。
对于定义几个信号量,每个信号量的初值是多少?可以这么考虑,我们需要控制几个点?比如上图中的两个进程,我们一边还要控制write进程的写入,又要控制read进程的输出,很显然这是需要两个的,然后一般要首先执行的应该给他的初始值定义为1,一旦进行P操作—1之后就可以继续执行。
上面这个推算过程不是准确无误的只能说我们在没有头绪的时候可以尝试这样想,但是这样也不能推算出就是需要两个,势必第一个的初始值就是1。在我们进行猜测之后我们还得根据要求不断尝试P V操作的位置能否满足需要的结果。
按照我们图中所定义的两个信号量初值和PV操作来分析分析是否能达到目的
首先看图
分析如下:首先对write中输入的核心代码进行操作,在上面对PS1进行P操作,P操作是给S—1此时S1=0,write进程继续执行,到核心代码之后对PS2进行V操作,V操作