进程同步——读者-写者问题

读者-写者问题

互斥制约与合作制约双重关系的进程同步问题描述是:

        一个被多个进程共享的文件、记录或数据结构,允许进程对其执行读、写操作。读进程称为读者,写进程称为写者。其允许多个进程同时读取,但只要有一个进程在读,就不能有进程对其进行写操作。同样,只要有一个进程在写,其它进程的读、写操作都不允许。

semaphore mutex = 1;
semaphore rwmutex = 1;
int readcount = 0;

void reader{
    while(true){
        wait(mutex);//避免多个读者同时操作readcount,给readcount加锁
        readcount++;
        if(readcount == 1){//只有第一个读者加锁,
            wait(rwmutex);//如果前面已经有读者了,代表可以直接读
        }
        signal(mutex);
        
        //读。。。
        
        wait(mutex);
        readcount--;
        if(readcount == 0){
            signer(rwmutex); 
        }
        signal(mutex);
    }
}

void writer{
    while(true){
        wait(rwmutex);
        //写。。。
        signer(rwmutex);
    }
}

读者-写者(2)

        在前面的基础上加了个条件,同一时刻最多又能有m个读者同时读

//用信号量集
semaphore remutex = m;
semaphore wrmutex = 1;

void reader{
    while(true){
       //remutex, 1, 1 
       //第一个1 表示 remutex的值如果小于1(读者数已经到ml),就阻塞,第二个1代表每次remutex减1
       //wrmutex, 1, 0 表示 wrmutex的值如果小于1(说明已经有写者了),就阻塞,0代表读者不影响写者
       Swait(remutex, 1, 1 ; wrmutex, 1 ,0); 
       //读。。。
		Ssignal(remutex,1);
    }
}

void writer{
    while(true){
        //remutex的数量初始为0,只有当读者进入临界区才会减1,
        //只要remutex的值小于m就阻塞,就代表已经有读者在访问了,阻塞
        Swait(rwmutex,1,1; remutex,m,0);
        //写。。。
        Ssigner(rwmutex,1);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值