IPC(进程间通信) | 信号量机制

本文介绍了Linux下进程间通信的几种方式,重点讲解了信号量机制用于进程同步的概念,包括信号量的数据结构、作用以及P/V操作。通过示例展示了未使用和使用信号量时程序的运行效果,说明了信号量如何确保进程的互斥访问并避免竞争条件。
摘要由CSDN通过智能技术生成

1. 进程间的通信方式

进程间的通信有以下几种方式:

1. 管道:管道分为有名管道和无名管道
2. 信号量:通过控制多个进程对临界资源的访问,使得同一时刻只允许一个进程对临界资源进行访问
3. 共享内存:把一块内存空间映射到两个进程的地址空间中,使得他们能够访问同一块内存空间,达到数据的共享。
4. 消息队列:向消息队列中添加数据,从消息队列中读取数据

2. 信号量机制进行进程同步

什么是信号量?信号量(semaphore)的数据结构为一个值和一个指针,指针指向等待该信号量的下一个进程。信号量的值与相应资源的使用情况有关。
当它的值大于0时,表示当前可用资源的数量;
当它的值小于0时,其绝对值表示等待使用该资源的进程个数。
注意,信号量的值仅能由PV操作来改变。

同步:对临界资源的互斥访问
临界区:访问临界资源的代码段
临界资源:同一时刻只能有一个进程来访问的资源

3. 原子操作P/V

P : 申请一个资源 资源数目减一,获取资源,进程进入,可能会发生阻塞.
V : 释放一个资源,资源数目加一,释放资源,进程出来,不会发生阻塞

使用PV操作实现进程互斥时应该注意的是:
(1)每个程序中用户实现互斥的P、V操作必须成对出现,先做P操作,进临界区,后做V操作,出临界区。若有多个分支,要认真检查其成对性。
(2)P、V操作应分别紧靠临界区的头尾部,临界区的代码应尽可能短,不能有死循环。
(3)互斥信号量的初值一般为1。

不加同步信号量的程序:

程序A.c

   #include<stdlib.h>
   #include<stdio.h>
   #include<unistd.h>
   #include<string.h>
   #include<assert.h>
   int main()
   {
   
       int i=0;
       for(;i<5;i++)
      {
   
          write(1,"A",1);
          int n=rand()%3;
          sleep(n);
          write(1,"A",1);
          n=rand()%3;
          sleep(n);
      }
      sleep(10);
      exit(0);
  } 

程序B.c

  #include<stdlib.h>
  #include<stdio.h>
  #include<unistd.h>
  #include<string.h>
  #include<asser
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值