Linux进程间通信

1.进程间通信介绍

  • 进程间通信(IPC)指的是2个任意进程之间的通信进程用户空间是相互独立的,一般而言是不能相互访问的。但很多情况下进程间需要互相通信,来完成系统的某项功能。进程通过与内核及其它进程之间的互相通信来协调它们的行为。
  • 一个进程在一个地址空间中它的不同模块之间通信都是很简单的(全局变量、通过函数形参实参传递)。但是2个不同的进程处于不同的地址空间,要互相通信很难。
  • 大部分程序是不需要进程间通信的,因为它们都是单进程的(可以多线程)。复杂、大型的程序(如GUI程序、服务器程序)才可能用到进程间通信,整个程序就设计成多个进程同时工作来完成的模式。

2.Linux内核提供的进程间通信机制

  • 无名管道和有名管道
  • SystemV IPC:信号量、消息队列、共享内存
  • Socket域套接字
  • 信号

3.管道

管道(一般就指无名管道)具有如下特点:

  • 管道的本质就是内核维护的一块内存(内核在内存中创建一个共享文件),管道是单向通信,半双工的,它有读端和写端。
  • 管道只能在父子进程间通信,父进程创建管理后fork子进程,子进程继承父进程的管道fd。

在这里插入图片描述
管道通信的函数:pipe、write、read、close
有名管道(实质就是可以在不是父子进程关系的而两个进程间通信的有名管道)具有如下特点:

  • 有名管道实质也是内核维护的一块内存,表现形式为一个有名字的文件。它不限父子进程,任意2个进程都可。有名管道固定一个文件名,2个进程分别使用mkfifo创建fifo文件,然后分别open打开获取到fd,然后一个读一个写。
  • 管道通信的函数:mkfifo、open、write、read、close

4.SystemV IPC

SystemV IPC通过一些专用API来提供进程间通信功能,分为信号量、消息队列、共享内存,其实质也是内核提供的公共内存。
消息队列

  • 本质上是一个队列,队列可以理解为(内核维护的一个)FIFO。
  • 工作时A和B2个进程进行通信,A向队列中放入消息,B从队列中读出消息。

信号量

  • 实质就是个计数器(其实就是一个可以用来计数的变量,可以理解为int a)。
  • 通过计数值来提供互斥和同步。

共享内存

  • 大片内存直接映射。
  • 类似于LCD显示时的显存用法。

5.剩余的2类进程间通信

1.信号
2.域套接字 socket。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值