管道通信

一、进程通信的目的: 
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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值