Linux系统编程之进程间的通信方式(无名管道与命名管道)

进程间的五种通信方式(IPC):1、管道(无名管道),速度慢,容量有限,只有父子进程能通讯;2、FIFO(命名管道),任何进程间都能通讯,但速度慢;3、消息队列,容量受到系统限制;4、信号量,不能传递复杂消息,只能用来同步;5、共享内存区。一、管道:管道:通常指无名管道,是UNIX系统中IPC最古老的形式。1.特点:它是半双工的(即数据只能在一个方向上流动),具有固定的读端和写端。它只能用于具有亲缘关系的进程之间的通信(也是父子进程或者兄弟进程之间)。它可以看成是一种特殊的文件,对于它的读写也
摘要由CSDN通过智能技术生成

进程间的五种通信方式(IPC):
1、管道(无名管道),速度慢,容量有限,只有父子进程能通讯;2、FIFO(命名管道),任何进程间都能通讯,但速度慢;3、消息队列,容量受到系统限制;4、信号量,不能传递复杂消息,只能用来同步;5、共享内存区。

一、管道:
管道:通常指无名管道,是UNIX系统中IPC最古老的形式。
1.特点:
它是半双工的(即数据只能在一个方向上流动),具有固定的读端和写端。
它只能用于具有亲缘关系的进程之间的通信(也是父子进程或者兄弟进程之间)。
它可以看成是一种特殊的文件,对于它的读写也可以使用普通的read、write 等函数。但是它不是普通的文件,并不属于其他任何文件系统,并且只存在于内存中。

2.原型:

 #include <unistd.h>
 int pipe(int pipefd[2]);

当一个管道被创建时,它会伴随着创建两个文件描述符,fd[0]为读而打开,fd[1]为写而打开。
如下图所示:
在这里插入图片描述
想关闭管道只要将两个文件描述符关闭即可。

3.用例说明:
单个进程中的管道几乎是没意义的,所以在调用pipe创建管道的时候,接着就调用函数fork()创建子进程,这样就实现了父进程与子进程之间的IPC方式。
(1)在使用fork()之后的半双工通信管道
在这里插入图片描述
(2)简单的从父进程到子进程之间的通信管道
在这里插入图片描述
直接上代码:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>

int main()
{
   
        //int pipe(int pipefd[2]);

        int fd[2];
        int pid;
        char *wbuf = "hello word!";
        char *rbuf = NULL;

        if(pipe(fd) == -1)
        {
   
                printf("creat pipe error!\n");
        }

        pid = fork();

        if(pid < 0)
        {
   
                printf("creat Process error!\n");
        }
        else if(pid > 0)
        {
   
                sleep(3);
                printf("this is father process!\n");
                close(fd[0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值