使用管道实现进程间的双向通信

原创 2012年03月29日 23:13:10
#include<stdio.h>
#include<unistd.h>


int main(int argc, char * argv[])
{
        int f_des1[2];
        int f_des2[2];


        int pid;
        char msg[BUFSIZ];
        char p_msg[BUFSIZ];


        if(argc != 2)
        {
                printf("Usage: %s message\n",argv[0]);
                return 1;
        }


        if(pipe(f_des1) == -1)
        {
                printf("cannot create the IPC pipe");
                return 1;
        }


        pid = fork();
        if(pid == -1)
        {
                printf("cannot create new process");
                return 1;
        }
        else if(pid == 0)
        {
                close(f_des1[1]);
                close(f_des2[0]);


                if(read(f_des1[0], msg, BUFSIZ) == -1)
                {
                        printf("child process cannot read data from pipe");
                        return 1;
                }
                else
                {
                        printf("in child proccess, receive message: %s\n",msg);
                }
                if(write(f_des2[1], msg, strlen(msg)) == -1)
                {
                        printf("child process cannot write data to pipe");
                        return 1;
                }
                else
                {
                        printf("in child process , send message back: %s\n", argv[1]);
                }
                exit(0);
        }
        else
        {
                close(f_des1[0]);
                close(f_des2[1]);


                if(write(f_des1[1], argv[1], strlen(argv[1])) == -1)
                {
                        printf("parent process cannot write data to pipe");
                        return 1;
                }
                else
                {
                        printf("in parent process , send mwssage: %s\n",argv[1]);  
                }


                if(read(f_des2[0], p_msg, BUFSIZ) == -1)
                {
                        printf("parent process cannot read data from pipe");
                        return 1;
                }
                else
                {
                        printf("in parent proccess, receive message: %s\n",p_msg);
                }
                wait(NULL);
                exit(0);
        }
        return 0;
}                                                                                                    
                                  

命名管道用于进程间双向通信

  • 2017年05月10日 11:49
  • 4.68MB
  • 下载

Android中通过Messenger与Service实现进程间双向通信

转载博客原文:http://blog.csdn.net/iispring/article/details/48329925 Android中的Service和其调用者既可以在同一个App中,也可...

Linux----进程间通信-管道与两个命名管道实现进程双向通信

在Linux系统中,有时候需要多个进程之间相互协作,共同完成某项任务,进程之间或线程之间有时候需要传递信息,有时候需要同步协调彼此工作,则就会出现进程间通信(interprocess communi...

【Unix/Linux编程实践】用管道实现双向通信—以bc计算器为例

前言几乎每个版本的Unix都包含bc计算器。事实上,大多数版本的bc只分析输入,然后在内部启动了dc计算器程序,并通过管道与其通信。dc是一个基于栈的计算器,它接收逆波兰表达式,执行运算后将结果送到标...

使用socketpair⽤来创建双向通信的管道

#include #include #include #include #include #include int main() { pid_t pid; int fd[2]; socketp...

Android Service进程间双向通信之Messenger(系列4)

转载请注明出处:http://blog.csdn.net/zhangphil Android Service进程间双向通信之Messenger(系列4) 附录文章2虽然利用Service的...

Android Messenger进程间双向通信详解

Android Messenger进程间双向通信详解在实现Messenger通信之前,我们先要完成一个前提条件:将一个组件通过调用bindService()绑定到服务上。这是将组件绑定到服务上我们要做...

使用Handler实现Service和Activity之间的双向通信

使用Handler实现Service和Activity之间的双向通信 分类:学习笔记 Service和Activity之间通信一般来说用的比较多的就是广播和Ha...

JavaSE第一百一十讲:使用线程实现服务器端与客户端的双向通信

在上一讲中我们讲到了服务器端与客户端的双向通信的例子,显然这种双向通信不是非常好,因为服务端与客户端建立连接之后,服务端一定要等待客户端的输入然后自己再返回一个输出,这在实际的开发过程显然是没有任何意...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用管道实现进程间的双向通信
举报原因:
原因补充:

(最多只允许输入30个字)