日期:2014-05-16 浏览次数:20846 次
Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
参考:《linux编程从入门到精通》,《Linux C程序设计大全》,《unix环境高级编程》
说明:本文非常的长,也是为了便于查找和比较,所以放在一起了
Linux 传统的进程间通信有很多,如各类管道、消息队列、内存共享、信号量等等。但它们都无法介于内核态与用户态使用,原因如表
通信方法 | 无法介于内核态与用户态的原因 |
管道(不包括命名管道) | 局限于父子进程间的通信。 |
消息队列 | 在硬、软中断中无法无阻塞地接收数据。 |
信号量 | 无法介于内核态和用户态使用。 |
内存共享 | 需要信号量辅助,而信号量又无法使用。 |
套接字 | 在硬、软中断中无法无阻塞地接收数据。 |
一.进程
1.进程表
ps显示正在运行的进程
# ps -ef
TIME 进程目前占用的cpu时间,CMD显示启动进程所使用的命令