管道,共享内存,消息队列,linux进程间通讯的几种方式的特点和优缺点,和适用场合。IPC

本文详细介绍了Linux环境下进程间通信(IPC)的多种方式,包括管道、信号量、消息队列、共享内存、套接字等。每种方式的特点、优缺点以及适用场景都有所阐述,帮助读者理解如何在不同情况下选择合适的进程通信机制。

http://www.360doc.com/content/19/0514/10/63975758_835593096.shtml

进程间通信(IPC)_进程间通信ipc-CSDN博客

总结

  • 简单通信:优先选管道或信号。

  • 高性能需求:共享内存 + 信号量。

  • 跨网络通信:套接字。

  • 同步协调:System-V/POSIX信号量。

  • 现代开发:优先使用 POSIX 接口(更简洁、跨平台)。

linux进程间通讯的几种方式的特点和优缺点,和适用场合。

http://www.360doc.com/showweb/0/0/969085200.aspx

 

进程之间的通信方式

管道(PIPE) (1)有名管道:一种半双工的通信方式,它允许无亲缘关系进程间的通信 ①优点:可以实现任意关系的进程间的通信 ②缺点:a、长期存于系统中,使用不当容易出错;b、缓冲区有限 (2)无名管道:一种半双工的通信方式,只能在具有亲缘关系的进程间使用(父子进程) ①优点:简单方便 ②缺点:a、局限于单向通信;b、只能创建在它的进程以及其有亲缘关系的进程之间;c、缓冲区有限

信号量(Semaphore):一个计数器,可以用来控制多个线程对共享资源的访问 ①优点:可以同步进程 ②缺点:信号量有限

信号(Signal):一种比较复杂的通信方式,用于通知接收进程某个事件已经发生

消息队列(Message Queue):是消息的链表,存放在内核中并由消息队列标识符标识 ①优点:可以实现任意进程间的通信,并通过系统调用函数来实现消息发送和接收之间的同步,无需考虑同步问题,方便 ②缺点:信息的复制需要额外消耗 CPU 的时间,不适宜于信息量大或操作频繁的场合

共享内存(Shared Memory):映射一段能被其他进程所访问的内存,这段共享内存由一个进程创建,但多个进程都可以访问 ①优点:无须复制,快捷,信息量大 ②缺点:a、通信是通过将共享空间缓冲区直接附加到进程的虚拟地址空间中来实现的,因此进程间的读写操作的同步问题;b、利用内存缓冲区直接交换信息,内存的实体存在于计算机中,只能同一个计算机系统中的诸多进程共享,不方便网络通信

套接字(Socket):可用于不同计算机间的进程通信 ①优点: a、传输数据为字节级,传输数据可自定义,数据量小效率高; b、传输数据时间短,性能高; c、适合于客户端和服务器端之间信息实时交互; d、可以加密,数据安全性强; ②缺点:需对传输的数据进行解析,转化成应用级的数据。 更多详见 C++基础语法梳理:进程与线程!知识点详细梳理

7、线程之间的通信方式

锁机制 包括互斥锁/量(mutex)、读写锁(reader-writer lock)、自旋锁(spin lock)、条件变量(condition)

  1. 互斥锁/量(mutex):提供了以排他方式防止数据结构被并发修改的方法。
  2. 读写锁(reader-writer lock):允许多个线程同时读共享数据,而对写操作是互斥的。
  3. 自旋锁(spin lock)与互斥锁类似,都是为了保护共享资源。互斥锁是当资源被占用,申请者进入睡眠状态;而自旋锁则循环检测保持者是否已经释放锁。
  4. 条件变量(condition):可以以原子的方式阻塞进程,直到某个特定条件为真为止。对条件的测试是在互斥锁的保护下进行的。条件变量始终与互斥锁一起使用。

信号量机制(Semaphore)

  1. 无名线程信号量
  2. 命名线程信号量 信号机制(Signal):类似进程间的信号处理 屏障(barrier):屏障允许每个线程等待,直到所有的合作线程都达到某一点,然后从该点继续执行。 线程间的通信目的主要是用于线程同步,所以线程没有像进程通信中的用于数据交换的通信机制



作者:红尘氵梦
链接:c++ 常用面试题整理(不定时更新)_牛客网
来源:牛客网








 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值