45.(7分)三个进程P1、P2、P3互斥使用一个包含N(N>0)个单元的缓
2021.06.27 07:07

  【题目】

  45.(7分)三个进程P1、P2、P3互斥使用一个包含N(N>0)个单元的缓冲区。P1每次用produce( )生成一个正整数并用put( )送入缓冲区某一空单元中;P2每次用getodd( )从该缓冲区中取出一个奇数并用countodd( )统计奇数个数;P3每次用geteven( )从该缓冲区中取出一个偶数并用counteven( )统计偶数个数。请用信号量机制实现这三个进程的同步与互斥活动,并说明所定义信号量的含义。要求用伪代码描述。

  【答案要点】

  (1) 缓冲区是一互斥资源,因此设互斥信号量mutex。

  (2) 同步问题:P1、P2因为奇数的放置与取用而同步,设同步信号量odd;P1、P3因为偶数的放置与取用而同步,设同步信号量even;P1、P2、P3因为共享缓冲区,设同步信号量empty。

  semaphore mutex = 1 ;

  semaphore odd = 0, even = 0 ;

  semaphore empty = N ;

  main ( )

  cobegin {

  Process P1 while ( True )

  {

  number = produce ( ) ; P (empty) ;

  P (mutex) ;

  put ( ) ;

  V (mutex) ;

  if number% 2 = = 0 V (even) ;

  else V(odd) ;

  {

  Process P2 while (True) P(odd) ;

  P(mutex) ;

  getodd ( ) ;

  V(mutex) ;

  V (empty) ; countodd ( ) ;

  {

  Process P3 while (true)

  {

  P (even) ;

  P(mutex) ; geteven( ) ; V (mutex) ;

  V (empty) ; counteven ( ) ;

  {

  } coend


MORE+

    相关阅读 MORE+

    版权及免责声明
    1.凡本网注明"稿件来源:新东方在线"的所有文字、图片和音视频稿件,版权均属北京新东方迅程网络科技有限公司所有,任何媒体、网站或个人未经本网协议授权不得转载、链接、转贴或以其他方式复制发表。已经本网协议授权的媒体、网站,在下载使用时必须注明"稿件来源:新东方在线",违者本网将依法追究责任。
    2.本网末注明"稿件来源:新东方在线"的文/图等稿件均为转载稿,本网转载出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如其他媒体、网站或个人从本网下载使用,必须保留本网注明的"稿件来源",并自负版权等法律责任。如擅自篡改为"稿件来源:新东方在线”,本网将依法追究责任。
    3.如本网转载稿涉及版权等问题,请作者致信weisen@xdfzx.com,我们将及时外理

    Copyright © 2011-202

    All Rights Reserved