管道通信之无名管道---pipe()
pipe()函数在子进程产生之前就应该存在。
- 父子进程之间只进行一次传递
/*============================================
> Copyright (C) 2014 All rights reserved.
> FileName:onepipe.c
> author:donald
> details:
==============================================*/
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define N 512
int main(int argc, const char *argv[])
{
int pipefd[];
pid_t pid; if(pipe(pipefd) == -){
perror("pipe failed");
exit(-);
}
printf("%u\n",pid);
pid == fork();//这里一个个大大的bug,自己的误操作,debug了很久才搞定了
printf("%u\n",pid);
if( == pid){
close(pipefd[]);//0 read 1 write
//一个约定,父子进程都需遵守 char buf[N];
memset(buf,,N);
read(pipefd[],buf,N);
printf("child read:%s\n",buf); printf("child exit\n");
exit();
}else{
close(pipefd[]);//0 read
char line[N];
printf("parent begin\n"); memset(line,,N);
fgets(line,N,stdin); write(pipefd[],line,strlen(line));
printf("parent exit\n");
wait(NULL);//等待子进程的结束
}
return ;
} 父子进程通过管道,进行多次读写操作,先贴上一个比较奇葩的方法(就是一个错误):
/*============================================
> Copyright (C) 2014 All rights reserved.
> FileName:my_pipe.c
> author:donald
> details:
==============================================*/
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define N 1024
int main(int argc, const char *argv[])
{
int fds[];
if(pipe(fds) == -){//只能有一对进行读写
perror("failed");
exit();
}
pid_t pid = fork();
if(pid == -){
perror("error");
exit();
} while(){
if(pid == ){//child read
close(fds[]);//1 write
char buf[] = "";
read(fds[],buf,);//只能有一个读,
printf("child read:%s\n",buf);
//exit(1);
}else{//parent write close(fds[]);//0 read
// char *p = "hello,donald";
char line[N];
// memset(line,0,N);
fgets(line,N,stdin);
write(fds[],line,strlen(line));
//wait(NULL);
}
}
return ;
}再贴上正确的方法:
/*============================================
> Copyright (C) 2014 All rights reserved.
> FileName:twopipe.c
> author:donald
> details:
==============================================*/
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define N 512
int main(int argc, const char *argv[])
{
int pipefd[];
pid_t pid;
//pid = fork(); if(pipe(pipefd) == -){
perror("pipe failed");
exit(-);
}
pid = fork();
if(pid == ){
close(pipefd[]);//0 read
char buf[N];
while(){
memset(buf,,N);
if(read(pipefd[],buf,N) == ){
break;
}
printf("child read:%s\n",buf);
}
printf("child exit\n");
exit();
}else{
close(pipefd[]);
char line[N];
while(memset(line,,N),fgets(line,N,stdin) != NULL ){
write(pipefd[],line,strlen(line));
}
close(pipefd[]);
printf("parent exit\n");
wait(NULL);
}
return ;
}
管道通信之无名管道---pipe()的更多相关文章
- Linux 进程通信(无名管道)
无名管道 无名管道是半双工的,就是对于一个管道来讲,只能读,或者写. 无名管道只能在相关的,有共同祖先的进程间使用(即一般用户父子进程). 一个fork或者execve调用创建的子进程继承了父进程的文 ...
- linux进程篇 (三) 进程间的通信1 管道通信
通信方式分4大类: 管道通信:无名管道 有名管道 信号通信:发送 接收 和 处理 IPC通信:共享内存 消息队列 信号灯 socke 网络通信 用户空间 进程A <----无法通信----> ...
- Linux 进程间通信 无名管道(pipe)
无名管道: 1)只能用于具有亲缘关系的进程之间的通信(无名管道是某一个进程创建的,不像普通文件有路径,在文件系统中是不可见的,其他进程要想打开,只能通过继承的方式去打开) 2)半双工的通信模式,具有固 ...
- linux命名管道通信过程
前一个道,这节学习命名管道. 二命名管道 无名管道仅仅能用来在父子进程或兄弟进程之间进行通信,这就给没有亲缘关系的进程之间数据的交换带来了麻烦.解决问题就是本节要学习的还有一种管道通信:命名管道. 命 ...
- PHP多进程编程(2):管道通信
一个进程如果是个人英雄主义,那么多进程就是集体主义.(不严格区分多进程 和 多线程的差别) 你不再是一个独行侠,而是一个指挥家. 独来独往,非常自由自在,但是,很多时候,不如众人拾柴火焰高. 这就是我 ...
- c# c++通信--命名管道通信
进程间通信有很多种,windows上面比较简单的有管道通信(匿名管道及命名管道) 最近做个本机c#界面与c++服务进行通信的一个需求.简单用命名管道通信.msdn都直接有demo,详见下方参考. c+ ...
- linux进程的管道通信
linux进程的管道通信 要求 编程实现进程的管道通信,掌握管道通信的同步和互斥机制. 相关函数 pipe管道 指用于连接一个读进程和一个写进程以实现他们之间通信的一个共享文件,又名pipe文件.向管 ...
- Linux简单程序实例(GNU工具链,进程,线程,无名管道pipe,基于fd的文件操作,信号,scoket)
一, GNU工具链简介: (1)编译代码步骤: 预处理 -> 编译 -> 汇编 -> 链接: 预处理:去掉注释,进行宏替换,头文件包含等工作: gcc -E test.c -o te ...
- 进程间通信IPC之--无名管道(pipe)和有名管道(fifo)(转)
进程间通信IPC之--无名管道(pipe)和有名管道(fifo) 2012-01-17 22:41:20 分类: C/C++ 每个进程各自有不同的用户地址空间,任何一个进 程的全局变量在另一个进程中 ...
随机推荐
- Sicily 1790. Single Round Match
高进度求余 或者 将一个数奇位上的数字与偶位上的数字分别加起来,再求它们的差,如果这个差是11的倍数(包括0),那么,原来这个数就一定能被11整除. #include <iostream> ...
- python给多个发送邮件附件,参考于《python自动化运维》
#!/usr/bin/env python #coding: utf-8 #author:luodi date:2015/02/12 #description:this is a send mail ...
- asp.net实现伪静态遇到的问题
之前在一次项目(asp.net网站)中要用到伪静态技术,实现的思路大致是这样的: 在全局配置文件Global.asax(普通的类可以通过实现IHttpModule来完成)中的Application_B ...
- [转]Linux下转换字符集(UTF8转换)
今天在Linux 下使用 Iconv 命令转换一个UTF8文件时,总是转换不成功.提示: iconv: 未知 0 处的非法输入序列 后来使用 man iconv 查看,还是没发现异常,因为命令格式都是 ...
- 初学swift笔记 结构体(八)
import Foundation /* 和类很相似 结构体 -> 封装 属性.方法 结构体是值类型 */ //定义一个LSQ类型的结构体 关键字struct struct LSQ { var ...
- mysql 匹配update
update 语句示例: UPDATE `zjzc`.`QRTZ_SCHEDuler_state` SET `ip`='220.191.34.246' WHERE `sn`='3117764' and ...
- zookeeper 各节点数据保证是弱一致性
一致性保证: ZooKeeeper 是一个高性能的,可扩展的服务.不管是读和写操作是被设计成快速,虽然读比写快. 这样做的原因是在读的情况下,Zookeeper 可以提供旧的数据, 反过来又是由于Zo ...
- thinkphp中的where()方法
where方法的用法是ThinkPHP查询语言的精髓,也是ThinkPHP ORM的重要组成部分和亮点所在,可以完成包括普通查询.表达式查询.快捷查询.区间查询.组合查询在内的查询操作.where方法 ...
- OSCHina技术导向:Java WEB企业门户平台Liferay
Liferay 是一个完整的门户解决方案,基于J2EE的应用,使用了EJB以及JMS等技术,前台界面部分使用Struts MVC 框架,基于XML的portlet配置文件可以自由地动态扩展,使用了We ...
- 图数据库之Pregel
/* 版权声明:能够随意转载,转载时请务必标明文章原始出处和作者信息 .*/ author: 张俊林 节选自<大数据日知录:架构与算法>十四章.书籍文件夹在此 Pre ...