Linux C/C++:IPC通信

本文介绍了Linux下进程间通信(IPC)的基本概念、使用理由和常见技术,包括管道、命名管道、信号量、消息队列、共享内存和套接字。通过实例展示了C/C++中如何实现管道和命名管道,并提供了信号量的简要说明。
摘要由CSDN通过智能技术生成

进程间通信(IPC,Inter-Process Communication),指至少两个进程或线程间传送数据或信号的一些技术或方法。进程是计算机系统分配资源的最小单位(严格说来是线程)。每个进程都有自己的一部分独立的系统资源,彼此是隔离的。为了能使不同的进程互相访问资源并进行协调工作,才有了进程间通信。举一个典型的例子,使用进程间通信的两个应用可以被分类为客户端和服务器,客户端进程请求数据,服务端回复客户端的数据请求。有一些应用本身既是服务器又是客户端,这在分布式计算中,时常可以见到。这些进程可以运行在同一计算机上或网络连接的不同计算机上。
    进程间通信技术包括消息传递、同步、共享内存和远程过程调用。IPC是一种标准的Unix通信机制。
    使用IPC 的理由:
        1.信息共享:Web服务器,通过网页浏览器使用进程间通信来共享web文件(网页等)和多媒体;
        2.加速:维基百科使用通过进程间通信进行交流的多服务器来满足用户的请求;
        3.模块化;
        4.私有权分离。
    与直接共享内存地址空间的多线程编程相比,IPC的缺点:
        1.采用了某种形式的内核开销,降低了性能;
        2.几乎大部分IPC都不是程序设计的自然扩展,往往会大大地增加程序的复杂度。

Linux常用的进程间的通讯方式:

  1. 管道(pipe):管道可用于具有亲缘关系的进程间的通信,是一种半双工的方式,数据只能单向流动,允许一个进程和另一个与它有共同祖先的进程之间进行通信。
  2. 命名管道(name
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值