进程同步及经典问题

  1. 什么是进程同步?

进程的同步是一种协作,即处理某事件多个进程之间存在先后顺序。

举例:process1(简称p1)先加工数据A,把数据A传递给process2(简称p2)。p2拿到数据A之后才开始工作。这个过程属于同步。

2.生产者-消费者问题

        存在一块buff,生产者是把产生的条目放到buff中,消费者从buff中取走条目。但是buff满的情况下生产者不能再让buff中投递,buff空的时候消费者不能再取条目,同一时刻要么存(更新)条目要么取条目(二者互斥)。

这块buff是有n个槽位的有限缓冲区。生产者反复地生成新的item,并将它插入到缓冲区中。

假设缓冲区编号1~N-1,in和out分别是生产者和消费者指针,指向可执行条目,初始值均为空。

设置三个信号量控制生产者消费者读取:

  • full:表示有产品的缓冲区数,初始值为0;
  • empty:表示可供使用的缓冲区数,初始值为N;
  • mutex:互斥信号量,初始值为1,表示进程互斥访问临界区。保证任何时候只有一个进程在临界区中。

伪代码(P代表减操作,V代表加操作):

int in = NULL,out = NULL;

semaphore mutex = 1; // 信号量,初试资源可用

empty = N;full = 0;

生产者进程(Producer)

while(TRUE)

{

        P(empty); // 减少一个空位资源

        P(mutex); // 减一,锁住临界资源

        buffer(in);产品送往buffer

        in = (in+1)%N;

        V(mutex);// 加一,释放临界资源

        V(full); // 占用 一个空位

}

消费者进程(Consumer)

while(TRUE)

{

        P(full); // 减少一个空位资源

        P(mutex); // 减一,锁住临界资源

        buffer(out);从buffer中取出产品

        out = (out+1)%N;

        V(mutex);// 加一,释放临界资源

        V(empty); // 增加一个空位

}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值