`
f002489
  • 浏览: 274285 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

Linux的进程间、线程间通信方式小结

 
阅读更多
http://blog.csdn.net/alexlee1986/article/details/21227417

Linux系统中的进程间通信方式主要以下几种:
同一主机上的进程通信方式
   * UNIX进程间通信方式: 包括管道(PIPE), 有名管道(FIFO), 和信号(Signal)
   * System V进程通信方式:包括信号量(Semaphore), 消息队列(Message Queue), 和共享内存(Shared Memory)
网络主机间的进程通信方式
   * RPC: Remote Procedure Call 远程过程调用
   * Socket: 当前最流行的网络通信方式, 基于TCP/IP协议的通信方式.

一、进程间的通信方式
# 管道( pipe ):管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用。进程的亲缘关系通常是指父子进程关系。
# 有名管道 (namedpipe) : 有名管道也是半双工的通信方式,但是它允许无亲缘关系进程间的通信。
# 信号量(semophore ) : 信号量是一个计数器,可以用来控制多个进程对共享资源的访问。它常作为一种锁机制,防止某进程正在访问共享资源时,其他进程也访问该资源。因此,主要作为进程间以及同一进程内不同线程之间的同步手段。
# 消息队列( messagequeue ) : 消息队列是由消息的链表,存放在内核中并由消息队列标识符标识。消息队列克服了信号传递信息少、管道只能承载无格式字节流以及缓冲区大小受限等缺点。
# 信号 (sinal ) : 信号是一种比较复杂的通信方式,用于通知接收进程某个事件已经发生。
# 共享内存(shared memory ) :共享内存就是映射一段能被其他进程所访问的内存,这段共享内存由一个进程创建,但多个进程都可以访问。共享内存是最快的 IPC 方式,它是针对其他进程间通信方式运行效率低而专门设计的。它往往与其他通信机制,如信号两,配合使用,来实现进程间的同步和通信。
# 套接字(socket ) : 套解口也是一种进程间通信机制,与其他通信机制不同的是,它可用于不同及其间的进程通信。

二、线程间的通信方式

# 锁机制:包括互斥锁、条件变量、读写锁
   *互斥锁提供了以排他方式防止数据结构被并发修改的方法。
   *读写锁允许多个线程同时读共享数据,而对写操作是互斥的。
   *条件变量可以以原子的方式阻塞进程,直到某个特定条件为真为止。对条件的测试是在互斥锁的保护下进行的。条件变量始终与互斥锁一起使用。
# 信号量机制(Semaphore):包括无名线程信号量和命名线程信号量
# 信号机制(Signal):类似进程间的信号处理
    线程间的通信目的主要是用于线程同步,所以线程没有像进程通信中的用于数据交换的通信机制。


分享到:
评论

相关推荐

    Linux进程间通信-详解 (经典)

    通过以上内容,我们可以看到Linux进程间通信的多种方式各有特点,可以根据具体的应用场景选择合适的通信机制。无论是简单的管道通信还是复杂的套接口编程,每种方法都有其适用的场合。深入理解这些通信机制,有助于...

    深刻理解进程间通信

    套接字(Socket)是一种高级的进程间通信方式,不仅可以用于本地进程间的通信,还可以用于网络上的进程间通信。 **6.2 重要数据结构** 与套接字相关的数据结构包括`struct socket`、`struct sockaddr`等。 **6.3 ...

    Linux进程编程介绍 Linux进程编程介绍.TXT

    在Linux中,控制进程的主要方法包括创建新进程、终止进程以及父子进程间的通信等。 1. **创建新进程**:主要通过`fork()`系统调用来实现。`fork()`创建一个与父进程几乎完全相同的子进程,子进程继承了父进程的数据...

    精通LINUX下的C编程(配套光盘)第三部分

    6.1 进程间通信机制概述 6.2 信号处理 6.3 管道 6.4 System V IPC机制 6.5 小结 习题 第7章 线程操作 7.1 线程概述 7.2 线程管理 7.3 小结 习题 第8章 网络编程 8.1 概述 8.2 TCP/IP基础 8.3 BSD套接...

    精通LINUX下的C编程(配套光盘)第一部分

    6.1 进程间通信机制概述 6.2 信号处理 6.3 管道 6.4 System V IPC机制 6.5 小结 习题 第7章 线程操作 7.1 线程概述 7.2 线程管理 7.3 小结 习题 第8章 网络编程 8.1 概述 8.2 TCP/IP基础 8.3 BSD套接...

    精通LINUX下的C编程(配套光盘)第二部分

    6.1 进程间通信机制概述 6.2 信号处理 6.3 管道 6.4 System V IPC机制 6.5 小结 习题 第7章 线程操作 7.1 线程概述 7.2 线程管理 7.3 小结 习题 第8章 网络编程 8.1 概述 8.2 TCP/IP基础 8.3 BSD套接...

    Linux多线程服务端编程:使用muduo C++网络库

    3.4进程间通信只用TCP . . . . . . . . . . . . . . .. . . . . . . . . . . . . . 65 3.5多线程服务器的适用场合. . . . . . . . . . . . . . . . .. . . . . . . . . . 67 3.5.1必须用单线程的场合. . . . . . . ....

    linux中进程问题

    本代码通过一个简单的多线程场景展示了如何在Linux环境下使用信号量和线程来实现进程间的同步和通信。通过父子线程之间的互动,模拟了一个家庭成员之间传递水果的过程,形象地演示了信号量的使用方法。

    华清远见嵌入式linux应用程序开发技术详解下载(内部资料).rar

     7.2 Linux进程控制编程   7.3 Linux守护进程   7.4 实验内容   本章小结   思考与练习  第8章 进程间通信   8.1 Linux下进程间通信概述   8.2 管道通信   8.3 信号通信  8.4 共享内存  ...

    嵌入式Linux应用程序开发标准教程(第2版全)

    接着系统地讲解了嵌入式Linux的环境搭建,以及嵌入式Linux的I/O与文件系统的开发、进程控制开发、进程间通信开发、网络应用开发、基于中断的开发、设备驱动程序的开发以及嵌入式图形界面的开发等,并且还安排了丰富...

    嵌入式Linux C编程入门(第2版) PPT

    10.3 arm linux进程间通信api 301 10.3.1 管道通信 301 10.3.2 信号通信 303 10.3.3 共享内存 308 10.3.4 消息队列 309 10.4 arm linux线程相关api 312 10.5 linux守护进程 317 10.5.1 守护...

    linux网络编程-宋敬彬-part3

    4.3 进程间通信和同步 101 4.3.1 半双工管道 101 4.3.2 命名管道 107 4.3.3 消息队列 108 4.3.4 消息队列的一个例子 114 4.3.5 信号量 116 4.3.6 共享内存 121 4.3.7 信号 124 4.4 Linux下的线程 ...

    linux网络编程-宋敬彬-part2

    4.3 进程间通信和同步 101 4.3.1 半双工管道 101 4.3.2 命名管道 107 4.3.3 消息队列 108 4.3.4 消息队列的一个例子 114 4.3.5 信号量 116 4.3.6 共享内存 121 4.3.7 信号 124 4.4 Linux下的线程 ...

    linux 网络编程技巧

    **5.7 小结** TCP/IP协议族已经成为现代互联网的基础,其核心协议包括IP、TCP和UDP。 #### 五、Berkeley套接字 **6.1 引言** Berkeley套接字(Berkeley Sockets)是一种通用的网络编程API,它简化了网络编程的...

    UNIX网络编程 卷2 进程间通信 带完整书签,完整目录

    10.12 进程间共享信号量 205 10.13 信号量限制 206 10.14 使用FIFO实现信号量 206 10.15 使用内存映射I/O实现信号量 210 10.16 使用System V信号量实现Posix信号量 218 10.17 小结 224 习题 225 第11章 ...

    嵌入式Linux应用程序开发详解

    7.2 Linux进程控制编程 212 7.3 Linux守护进程 224 7.3.1 守护进程概述 224 7.3.2 编写守护进程 224 7.3.3 守护进程的出错处理 229 7.4 实验内容 232 7.4.1 编写多进程程序 232 7.4.2 编写...

    Linux程序设计中文第4版.part2

    已经整理好目录,需要下载3个包,因为只能上传50M,...第13章 进程间通信:管道 第14章 信号量、共享内存和消息队列 第15章 套接字 第16章 用GTK+进行GNOME编程 第17章 用Qt进行KDE编程 第18章 Linux标准33

    Linux程序设计中文第4版.part1

    已经整理好目录,需要下载3个包,因为只能上传50M,所以...第13章 进程间通信:管道 第14章 信号量、共享内存和消息队列 第15章 套接字 第16章 用GTK+进行GNOME编程 第17章 用Qt进行KDE编程 第18章 Linux标准33

    Linux程序设计 第4版.haozip01

    第13章 进程间通信:管道 443 13.1 什么是管道 443 13.2 进程管道 444 13.3 将输出送往popen 445 13.3.1 传递更多的数据 446 13.3.2 如何实现popen 447 13.4 pipe调用 449 13.5 父进程和子进程 451 13.5.1 ...

Global site tag (gtag.js) - Google Analytics