栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

Linux下进程间通信-------管道通信

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Linux下进程间通信-------管道通信

先来看原理:

 特点 :

1.半双工的通信方式(通信期间双方都可以发送/接收文件,但是不能双方同时发送/接收数据)

2.pipe只能用于父子进程间的通信

3.mkfifo可用于任意进程间的通信

代码逐步实现

首先创建管道文件:

 然后ls查看是否创建(因为我提前都写过了,所有文件夹中写端和读端都有了)

 然后进行写端的编写:

#include 
#include 
#include 
#include 
#include 
#include 
#include 
 
void sig_fun(int sig)//当读端或写端其中一方出错时不会直接终止掉程序 而是返回一个信号值
{
    printf("sig = %d n",sig);
}
 
int main()
{
    signal(SIGPIPE,sig_fun);
    int fdw = open("fifo",O_WRONLY);//打开管道文件 只写权限(该代码是以任意两进程间通信为例)
    assert(fdw != -1);

    while(1)//循环写入程序
    {
        printf("fdw = %dn",fdw);

        char buff[128] = {0};//将写入的数据存到buff中
        printf("inputs:n");
        fgets(buff,128,stdin);
        if(strncmp(buff,"end",3) == 0)//如果输入"end"则终止掉程序
        {
            break;
        }
        write(fdw,buff,strlen(buff));//将数据写入管道文件中
    }
    close(fdw); //关闭文件描述符
    exit(0);

}

读端的编写:

#include 
#include 
#include 
#include 
#include 
#include 

int main()
{
    int fdr = open("fifo",O_RDONLY);//从管道文件中读取数据  只读
    assert(fdr != -1);

    printf("fdr = %d n",fdr);

    while(1)
    {
        char buff[128] = {0};
        int n = read(fdr,buff,127);
        if(n == 0) //当写端GG的时候  读端没有读取到数据  然后读端跟着一起GG
        {
            break;
        }
        printf("  n   buff = %s n,n = %d n",buff,n);
    }
    close(fdr);//
    exit(0);

}

然后上述代码是任意两进程间的通信

使用的创建命令是mkfifo

然后下面来看pipe(父子进程间的通信)

先通过详细命令man pipe可以看到:

 pipe需要传入两个文件描述符:fd[0]是读的文件描述符

                                                   fd[1]是写的文件描述符

下面来看代码实现:

#include
#include
#include
#include
#include
#include

int main()
{
    int fd[2];\fd[0] 读   fd[1]  写
    int res = pipe(fd);
    assert(res != -1);
    
    pid_t pid = fork();
    assert(pid != -1);
    
    if(pid == 0) //pid == 0 是在子进程那块
    {
        close(fd[1]);
        char buff[128] = {0};
        read(fd[0],buff,127);
        printf("child read:%sn",buff);
        close(fd[0]);
    }    
    else //否则就在父进程那块
    {
        close(fd[0]);
        char buff[128] = {0};
        fgets(buff,128,stdin);        

        write(fd[1],buff,strlen(buff));
        close(fd[1]);
    }
}

该代码在执行之后,父子进程都在阻塞,父进程在等待输入fgets那块阻塞,子进程在read那块阻塞,然后你在输入之后,回车,子进程就会读出数据!

“如果你的长大还让父母那么劳累,那么你长大的意义是什么!”
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/458334.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号