0
点赞
收藏
分享

微信扫一扫

网编(10):客户端和服务器的进程间通信

通过管道实现进程间通信

#include <unistd.h>
int pipe(int filedes[2]);
//成功时返回0, 失败时返回-1。

#filedes[0] 通过管道接收数据时使用的文件描述符,即管道出口。
#filedes[1] 通过管道传输数据时使用的文件描述符,即管道入口。

网编(10):客户端和服务器的进程间通信_#define

实例代码:

#include <stdio.h>
#include <unistd.h>
#define BUF_SIZE 30

int main(int argc , char *argv[])
{
int fds[2];
char str[]="Who are you?";
char buf[BUF_SIZE];
pid_t pid;

pipe(fds);
pid=fork() ;
if(pid==0)
{
write(fds[l], str, sizeof(str)) ;
}
else
{
read(fds[0], buf, BUF_SIZE);
puts(buf);
}
return 0;
}

通过管道进行进程间双向通信

网编(10):客户端和服务器的进程间通信_#define_02

实例代码:

#include <stdio.h>
#include <unistd.h>
#define BUF_SIZE 30

int main(int argc , char *argv[])
{
int fds1[2], fds2[2];
char str1[]="Who are you?";
char str2[]="Thank you for your message";
char buf[BUF_SIZE];
pid_t pid;

pipe(fds1);
pipe(fds2);
pid=fork() ;
if(pid==0)
{
write(fds1[1], str, sizeof(str));
read(fds2[0], buf, BUF_SIZE);
printf("Child proc output: %s \n", buf)
}
else
{
read(fds1[0], buf, BUF_SIZE);
printf("Parent pr oc output: %s \n", buf);
write(fds2[1], str2, sizeof(str2));
sleep(3);
}
return 0;
}

 

 

 

 

 

 

 

 

 

 

举报

相关推荐

0 条评论