Linux进程间通信(一)基础篇

一些复杂的应用程序可能会需要多个进程分工协作来满足所需的功能需求,这就必然涉及到数据在进程之间的共享或交换,称 为IPC(Inter-process communication,进程间通信)。   

UNIX提供了许多工具(facilities)用于实现进程间通信,这些工具可以分为三类:

通信(Communication):用于进程间交换数据。
同步(Synchronization):同步进程(或线程)之间的动作(actions)。
信号(Signals):既可以用于同步,也可以用于通信(很少使用)。

数据传输和共享内存的区别

  1. 对于数据传输工具来说,一个进程的一次读操作将消耗 (consumes)数据,即读完之后,数据对于其它进程的读操作不可 用。而放置在共享内存中的数据对于所有的进程均可见。

  2. 对于数据传输工具来说,读进程和写进程之间的同步自动完成。 而共享内存需要程序员实现同步操作。

Linux 系统的 IPC接口
Linux系统的IPC接口主要由System V IPC,POSIX IPC以及BSD Socket构成。

BSD Socket BSD Socket BSD Socket BSD Socket socket不仅可以用于同一主机上的各个进程之间的通信,更主 要的是可以用于不同主机间的网络通信。

System V IPC System V IPC System V IPC System V IPC System V IPC接口是由AT&T的贝尔实验室发展出来的,其通 信机制主要包括管道、FIFO、消息队列,信号量、共享内存等。

POSIX IPC POSIX IPC POSIX IPC POSIX IPC 由于UNIX的分支版本众多,为了提高应用程序的可移植性, IEEE制定了POSIX。POSIX IPC主要包括消息队列、信号量、共 享内存等。
主要

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浮生卍流年

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值