Skip to content
Linux进程间通信(Inter-Process Communication)方式汇总
C Makefile
Branch: master
Clone or download
clpsz Merge pull request #3 from lihp1603/master
修改了几个小问题,更加规范化
Latest commit 4a04209 Jun 12, 2018
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
IPC_mutex Fix broken Markdown headings Apr 17, 2017
POSIX_sem Fix broken Markdown headings Apr 17, 2017
XSI_msgq 修改了几个小问题,更加规范化 May 30, 2018
XSI_sem Fix broken Markdown headings Apr 17, 2017
XSI_shm Fix broken Markdown headings Apr 17, 2017
domain_socket Fix broken Markdown headings Apr 17, 2017
fifo Fix broken Markdown headings Apr 17, 2017
mutex Fix broken Markdown headings Apr 17, 2017
pipe Fix broken Markdown headings Apr 17, 2017
signal Fix broken Markdown headings Apr 17, 2017
.gitignore add .gitignore file Apr 10, 2015
LICENSE add GPL liscense Apr 10, 2015
README.md

README.md

linux-IPCs

Linux进程间通信方式汇总

目前已包含的方式

  1. 管道(PIPE)
  2. FIFO(有名管道)
  3. XSI消息队列
  4. XSI信号量
  5. XSI共享内存
  6. POSIX信号量
  7. 域套接字(Domain Socket)
  8. 信号(Signal)
  9. 互斥量(Mutex)

其中信号(signal)和信号量(semaphore)本质上并不算是进程间通信方式,应该是进程间同步的方式,但是也可以起到一定的通信作用,故也列在上面。

另外普通的mutex是作用线程间同步用的,但是可以将进程A和进程B共享的内存中初始化一个mutex,这样就可以用将此mutex用作进程间通信用了。

扩展

进程与内核通信

其实本来的计划是分两个大块,一块写进程间通信,一块写内核与用户空间通信。后来时间有限,内核与进程间只写了一个netlink,所以没有放到这里,等以后有时间了再补充吧。

线程间同步

同一个进程的多个线程在同一个地址空间,通信是很容易的事情,因此多线程间要同步就好了。写了一个linux多线程的同步方式的汇总,在以下仓库中clpsz/linux-itss,供参考,欢迎讨论。

You can’t perform that action at this time.