Linux进程间通信编程(一)管道和信号
2016-10-03 13:09
176 查看
Linux进程间通信编程(一)管道和信号
进程间通信的目的:
1. 数据传输:一个进程需要将它的数据发送给另一个进程
2. 资源共享:多个进程之间共享同样的资源
3. 通知事件:一个进程需要向另一个或一组进程发送消息,通知他们发生了某种事件
4. 进程控制:有些进程需完全控制另一个进程的执行,此时控制进程希望能够拦截另一进程的所有操作并能及时知道他的状态改变
Linux使用的进程间通信方式包括:
1、 管道(pipe)和有名管道(FIFO)
单向,一个进程的输入和另一个进程的输出连接在一起。写进程在管道的尾部写入数据,读进程在管道的头部读出数据
通常先创建一个管道,(必须在系统调用fork( )前调用pipe(
),否则子进程将不会继承文件描述符,再通过fork函数创建一个子进程,该子进程会继承父进程所创建的管道
数据被一个进程读出后,将被从管道中删除,其它读进程将不能再读到这些数据。管道提供了简单的流控制机制,进程试图读空管道时,进程将阻塞。同样,管道已经满时,进程再试图向管道写入数据,进程将阻塞.。
管道 ——
无名管道 由pipe()函数创建将
用于父进程和子进程的通信
—— 有名管道
不相关的进程也能交换数据
2、 信号(signal)
产生信号条件:
1、当用户按某些按键时,产生信号
2、硬件异常产生信号、
3、进程用kill函数将信号发送给另一个进程
4、用户可用kill命令将信号发送给其他进程
常见的信号类型:
SIGHUP:
从终端上发出的结束信号
SIGINT:
来自键盘的中断信号(Ctrl-C)
SIGKILL:该信号结束接收信号的进程
SIGTERM:kill
命令发出的信号
SIGCHLD:标识子进程停止或结束的信号
SIGSTOP:来自键盘(Ctrl-Z)或调试程序的停止执行信号
信号处理方式
1,忽略此信号
SIGKILL\SIGSTOP决不能被忽略,它们向超级用户提供了一种终止或停止进程的方法
2、执行用户希望的动作
通知内核在某种信号发生时,调用一个用户函数。在用户函数中,执行用户希望的处理
3. 执行系统默认动作
v 信号处理方法:使用简单的signal函数,另一种是使用信号集函数组
信号发送:
1. kill函数:既可以向自身发送信号,也可以向其他进程发送信号
kill的pid参数有四种不同的情况:
1、pid>0
将信号发送给进程ID为pid的进程。
2、pid == 0
将信号发送给同组的进程。
3、pid < 0
将信号发送给其进程组ID等于pid绝对值的进程。
4、pid ==-1
将信号发送给所有进程。
2. raise函数:向进程自身发送信号
3、消息队列
4、共享内存
5、信号量
6、套接字(socket)
进程间通信的目的:
1. 数据传输:一个进程需要将它的数据发送给另一个进程
2. 资源共享:多个进程之间共享同样的资源
3. 通知事件:一个进程需要向另一个或一组进程发送消息,通知他们发生了某种事件
4. 进程控制:有些进程需完全控制另一个进程的执行,此时控制进程希望能够拦截另一进程的所有操作并能及时知道他的状态改变
Linux使用的进程间通信方式包括:
1、 管道(pipe)和有名管道(FIFO)
单向,一个进程的输入和另一个进程的输出连接在一起。写进程在管道的尾部写入数据,读进程在管道的头部读出数据
通常先创建一个管道,(必须在系统调用fork( )前调用pipe(
),否则子进程将不会继承文件描述符,再通过fork函数创建一个子进程,该子进程会继承父进程所创建的管道
数据被一个进程读出后,将被从管道中删除,其它读进程将不能再读到这些数据。管道提供了简单的流控制机制,进程试图读空管道时,进程将阻塞。同样,管道已经满时,进程再试图向管道写入数据,进程将阻塞.。
管道 ——
无名管道 由pipe()函数创建将
用于父进程和子进程的通信
—— 有名管道
不相关的进程也能交换数据
2、 信号(signal)
产生信号条件:
1、当用户按某些按键时,产生信号
2、硬件异常产生信号、
3、进程用kill函数将信号发送给另一个进程
4、用户可用kill命令将信号发送给其他进程
常见的信号类型:
SIGHUP:
从终端上发出的结束信号
SIGINT:
来自键盘的中断信号(Ctrl-C)
SIGKILL:该信号结束接收信号的进程
SIGTERM:kill
命令发出的信号
SIGCHLD:标识子进程停止或结束的信号
SIGSTOP:来自键盘(Ctrl-Z)或调试程序的停止执行信号
信号处理方式
1,忽略此信号
SIGKILL\SIGSTOP决不能被忽略,它们向超级用户提供了一种终止或停止进程的方法
2、执行用户希望的动作
通知内核在某种信号发生时,调用一个用户函数。在用户函数中,执行用户希望的处理
3. 执行系统默认动作
v 信号处理方法:使用简单的signal函数,另一种是使用信号集函数组
信号发送:
1. kill函数:既可以向自身发送信号,也可以向其他进程发送信号
kill的pid参数有四种不同的情况:
1、pid>0
将信号发送给进程ID为pid的进程。
2、pid == 0
将信号发送给同组的进程。
3、pid < 0
将信号发送给其进程组ID等于pid绝对值的进程。
4、pid ==-1
将信号发送给所有进程。
2. raise函数:向进程自身发送信号
3、消息队列
4、共享内存
5、信号量
6、套接字(socket)
相关文章推荐
- Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
- linux 进程间通信一(管道与信号)
- Linux进程间通信--信号,管道,消息队列,信号量,共享内存,socket
- Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
- linux 系统编程-学习笔记10--进程间通信--管道/FIFO/消息队列/
- Linux编程—进程间通信—无名管道(1)
- Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
- Linux进程间通信--信号,管道,消息队列,信号量,共享内存,socket
- Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
- Linux进程间通信之管道(pipe)、命名管道(FIFO)与信号(Signal)
- Linux编程练习 --进程间通信1--无名管道
- Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
- Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
- Linux进程间通信之管道(pipe)、命名管道(FIFO)与信号(Signal)
- Linux环境进程间通信----信号与管道
- Linux编程练习 --进程间通信2--两个管道实现双向通信
- Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
- Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存
- Linux进程间通信:管道,信号量,消息队列,信号,共享内存,套接字
- Linux进程间通信方式--信号,管道,消息队列,信号量,共享内存