socketpair 进程间全双工通信

原创 2016年06月01日 14:01:01
include <sys/socket.h>
#include <netinet/in.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <iostream>
using namespace std;
void err_sys(const char *errmsg);
class Person
{
  public:
   void say(string str )
   {
     int n;
     printf("%s say %s\n",name_.c_str(),str.c_str());
     if((n = write(say_sock_, str.c_str(), str.size() ))<0)
     {
        err_sys("write error!\n");
     }
   }
   string hear()
   {
     int n;
     string res;
     char s[1024];
     if ((n = read(hear_sock_,s , sizeof(s))) >0)
     {
        s[n]=0;
        res += s;
     }
     printf("%s hear %s\n",name_.c_str(),res.c_str());
     return res;
   }
   int say_sock_;
   int hear_sock_;
   Person()
   {
     say_sock_ = -1;
hear_sock_ = -1;
   }
   string name_;
};
int main(void)
{
        int sockfd1[2];
        pid_t pid;
        Person p1,p2;
        p1.name_="p1";
        p2.name_ = "p2";
        if ((socketpair(AF_LOCAL, SOCK_STREAM, 0, sockfd1))<0)
                err_sys("socketpair");
        if ((pid = fork()) == -1)
                err_sys("fork");
        else if (pid == 0)
        { /* child process */
                        p1.say_sock_ = sockfd1[0];
                        p1.hear_sock_ = sockfd1[0];

                        p1.say("hello world");
                        p1.hear();
                        p1.say("chile");
                        sleep(1);
        }
        else if (pid > 0)
        { /* parent process */
                        p2.hear_sock_ = sockfd1[1];
                        p2.say_sock_ = sockfd1[1];
                        p2.say("chifanlema ?");
                        p2.hear();
                        sleep(1);
        }
        return 0;
}
void err_sys(const char *errmsg)
{
        perror(errmsg);
        exit(1);
}
     

socketpair创建双向通信的管道(全双工通信)

socketpair创建双向通信的管道(全双工通信)
  • Li_Ning_
  • Li_Ning_
  • 2016年08月06日 22:03
  • 1448

进程间通信:管道和socketpair的区别

最近在总结之前做过的FTP服务器小项目时,突然想到服务进程和nobody进程之间的通信方式为什么不能采用其他方式时。查了点资料,总结就是socketpair和管道形式非常的类似,唯一的不同就是sock...
  • PirLCK
  • PirLCK
  • 2016年09月13日 15:44
  • 1087

java中进程间几种通信方式

进程间通信IPC------Inter-Process Communication  由于内存管理的一些机制,导致两个进程间并不能直接的进行通信(在独立的用户空间),因此我们需要利用一些介质来完成两...
  • baitxttgchx
  • baitxttgchx
  • 2012年10月09日 18:49
  • 7668

Python基础(八)---进程间通信-Queue

进程之间需要通信,操作系统提供了很多机制来实现进程间的通信 1.multiprocessing模块的QUEUE实现多进程之间的数据传递。Queue本身是一个消息队列程序。 初始化一个Queue对象...
  • tao3741
  • tao3741
  • 2017年08月06日 16:52
  • 155

在操作系统中,进程之间是如何通信的?

进程间通信(IPC),指的是进程之间信息交换,所交换的信息量少则是一个状态或树枝,多则是成千上万个字节。用于进程间通讯的方式分为两类: 共享内存,消息机制 分类一转载自 http://www.cn...
  • cczz598
  • cczz598
  • 2015年04月22日 16:39
  • 1621

Linux 进程间通信 socket

http://haibor1x.blog.163.com/blog/static/763407200751052458572/ 一个linux UDP网络通讯的例子源代码(server、client方...
  • zhx862012
  • zhx862012
  • 2016年01月13日 14:42
  • 1424

进程间通信:共享内存(代码实现)

共享内存:1.共享内存就是允许两个不相关的进程访问同一个逻辑内存;                     2.共享内存是在两个正在运行的进程之间共享和传递数据的一种最有效的方式;        ...
  • wangiijing
  • wangiijing
  • 2016年07月06日 18:17
  • 3608

SendMessage进程间简单通信问题

 本例以两个VC Dialog application 为例用SendMessage进行两进程间简单通信:主要API:FindWindow(LPCTSTR lpClassName,    LPCTST...
  • zzq_gates
  • zzq_gates
  • 2007年04月19日 17:29
  • 591

进程间通信--UDP

Server.c #include #include #include #include #include int main(void) { //...
  • DLUTBruceZhang
  • DLUTBruceZhang
  • 2013年05月01日 16:06
  • 2858

用socketpair()进行进程间的全双工通讯

socketpair() 进行全双工的IPC
  • chengshuguang
  • chengshuguang
  • 2013年12月01日 10:46
  • 844
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:socketpair 进程间全双工通信
举报原因:
原因补充:

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