一、进程通信的目的:
1.数据传输:一个进程需要将它的数据发送给另一个进程
2.资源共享:多个进程之间共享同样的资源
3.通知事件:一个进程需要向另一个或一组进程发送消息,通知它们发生了某种事件
4.进程控制:有些进程希望完全控制另一个进程的执行(如Debug进程),此时控制进程希望能够拦截另一个进程的所有操作,并能够及时知道它的状态改变
二、管道通信
• 管道是单向的、先进先出的,它把一个进程的输出和另一个进程的输入连接在一起。
• 一个进程(写进程)在管道的尾部写入数据,另一个进程(读进程)从管道的头部读出数据
• 数据被一个进程读出后,将被从管道中删除,其它读进程将不能再读到这些数据。
• 管道提供了简单的流控制机制,进程试图读空管道时,进程将阻塞。同样,管道已经满时,进程再试图向管道写入数据,进程将阻塞
• 管道包括无名管道和有名管道两种,前者用于父进程和子进程间的通信,后者可用于运行于同一系统中的任意两个进程间的通信。
无名管道创建:
int pipe(int filedis[2]);
当一个管道建立时,它会创建两个文件描述符:
filedis[0] 用于读管道,
filedis[1] 用于写管道
• 创建管道pipe
读管道read
写管道write
关闭管道close
• 管道用于不同进程间通信。通常先创建一个管道,再通过fork函数创建一个子进程,该子进程会继承父进程所创建的管道
• 1.管道通讯是单向的,有固定的读端和写端。2. 数据被进程从管道读出后,在管道中该数据就不存在了。3. 当进程去读取空管道的时候,进程会阻塞。4. 当进程往满管道写入数据时,进程会阻塞。5. 管道容量为64KB
• 必须在系统调用fork( )前调用pipe( ),否则子进程将不会继承文件描述符
函数整理:
①pipe
函数的作用:建立无名管道
函数的原型:int pipe(int filedes[2]);
头文件:#include < unistd.h >
返回值:成功0,出错-1
②mkfifo
函数的作用:创建有名管道
函数的原型:int mkfifo(const char *filename,mode_t mode);
参数的作用:filename:有名管道的路径、名称
mode:管道的方式
返回值:成功0,出错-1
③kill
函数的作用:传送信号给指定的进程
函数的原型:int kill(pid_t pid,int sig);
函数的参数:pid > 0:将信号传给进程识别码为pid的进程
pid = 0:将信号传给和目前进程相同进程组的所有进程
pid = -1:将信号广播传送给系统内所有的进程
pid < 0:将信号传给进程组识别码为pid绝对值的所有进程
sig:信号
返回值:成功0,出错-1
头文件:#include < sys/types.h >
#include < signal.h >
④raise
函数的作用:发送信号给自身
函数的原型:int raise(int sig);
头文件:#include < signal.h >
⑤alarm
函数的作用:设置信号传送闹钟
函数的原型:unsigned int alarm(unsigned int second);
返回值:返回之前闹钟的剩余秒数,如果之前未设闹钟则返回0
⑥pause
函数的作用:让进程暂停直到信号出现
函数的原型:int pause(void);
返回值:-1