Linux IPC(Inter-Process Communication,进程间通信)之管道学习
1.标准流管道
多进程学习中有具体介绍
2.无名管道(PIPE)
int main(){
int fds[2];
if(pipe(fds)==-1){
perror("pipe:");
return 0;
}
char buf[1024]="";
if(fork()==0){
close(fds[1]);
while(memset(buf,0,sizeof(buf))){
if(read(fds[0],buf,1024)==0){//当管道里没有数据的时候就退出
break;
}
printf("child:read:");
puts(buf);
}
exit(1);
}
else{
close(fds[0]);
// char p[1024];
// char *p="Hello world!";
while(memset(buf,0,1024),fgets(buf,1024,stdin)!=NULL)
write(fds[1],buf,1024);
close(fds[1]);
printf("parents,finish\n");
wait(NULL);//wait一定要放在close的后面,由于仅仅有先将父进程的fds[1]关掉,当子进程没有数据读的时候才会退出,否则会导致死锁
}
}
3命名管道(FIFO)
3.1创建,删除FIFO文件
#include<iostream>
using namespace std;
int main(int argc,char *argv[]){
if(mkfifo(argv[1],0666)==-1){
perror("ew");
return 0;
}
unlink(argv[1]);
}
3.2打开,关闭FIFO文件
fd_recv=open(argv[1],O_RDONLY);
fd_send=open(argv[2],O_WRONLY);
if(fd_send==-1){
perror("fd_send");
exit(1);
}
3.3读写FIFO
/*************************************************************************
> File Name: pork_send.c
> Author: yang
> Mail:826123027@qq.com
> Created Time: 2014年08月22日 星期五 19:54:08
************************************************************************/ #include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<memory.h>
int main(int argc,char *argv[]){
if(mkfifo(argv[1],0666)==-1){
perror("mkfifo1");
exit(1);
}
int fd_send,fd_recv;
fd_send=open(argv[1],O_WRONLY);
fd_recv=open(argv[2],O_RDONLY);
char buf_recv[1024]="";
char buf_send[1024]="";
printf("opening!\n");
if(fork()==0){//开皮一个进程,用来接受信息
close(fd_send);
while(memset(buf_recv,0,sizeof(buf_recv)),read(fd_recv,buf_recv,1024)>0){
write(1,buf_recv,strlen(buf_recv));
}
close(fd_recv);
exit(1);
}
close(fd_recv);
while(memset(buf_send,0,sizeof(buf_send)),fgets(buf_send,1024,stdin)!=NULL){
write(fd_send,buf_send,strlen(buf_send));//用来发送信息
}
close(fd_send);
wait(NULL);
}
/*************************************************************************
> File Name: pork_recv.c
> Author: yang
> Mail:826123027@qq.com
> Created Time: 2014年08月22日 星期五 20:12:32
************************************************************************/ #include<string.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<memory.h>
#include<stdio.h>
int main(int argc,char *argv[]){
if(mkfifo(argv[2],0666)==-1){
perror("mkfifo2");
exit(1);
}
int fd_send,fd_recv;
fd_recv=open(argv[1],O_RDONLY);//注意这里与上面程序的这个位置有所不一样
fd_send=open(argv[2],O_WRONLY);
char buf_recv[1024]="";
char buf_send[1024]="";
printf("opening!\n");
if(fork()==0){//接受信息
close(fd_send);
while(memset(buf_recv,0,sizeof(buf_recv)),read(fd_recv,buf_recv,1024)>0){
write(1,buf_recv,strlen(buf_recv));
}
close(fd_recv);
exit(1);
}
close(fd_recv);//发送信息
while(memset(buf_send,0,sizeof(buf_send)),fgets(buf_send,1024,stdin)!=NULL){
write(fd_send,buf_send,strlen(buf_send));
}
close(fd_send);
wait(NULL);
}
Linux IPC(Inter-Process Communication,进程间通信)之管道学习的更多相关文章
- Linux进程间通信之管道
1,进程间通信 (IPC ) Inter-Process Communication 比较好理解概念的就是进程间通信就是在不同进程之间传播或交换信息. 2,linux下IPC机制的分类:管道.信号.共 ...
- linux内核剖析(八)进程间通信之-管道
管道 管道是一种两个进程间进行单向通信的机制. 因为管道传递数据的单向性,管道又称为半双工管道. 管道的这一特点决定了器使用的局限性.管道是Linux支持的最初Unix IPC形式之一,具有以下特点: ...
- Linux进程间通信(一) - 管道
管道(pipe) 普通的Linux shell都允许重定向,而重定向使用的就是管道. 例如:ps | grep vsftpd .管道是单向的.先进先出的.无结构的.固定大小的字节流,它把一个进程的标准 ...
- linux IPC总结——管道
管道 管道是unix ipc的最古老形式,是一种在内存中的特殊文件,只能在具有公共祖先的进程之间使用(即父子进程,兄弟进程). 管道由pipe函数创建 #include <unistd.h> ...
- 【IPC第二个进程间通信】管道Pipe
IPC进程间通信+管道Pipe IPC(Inter-Process Communication,进程间通信). 管道用于进程间共享数据,事实上质是共享内存 ...
- Linux - 进程间通信 - 匿名管道
一.概念:进程间通信( IPC,InterProcess Communication) 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进城之间要交换数据必须通过内 ...
- Linux 进程间通信之管道(pipe),(fifo)
无名管道(pipe) 管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信: 定义函数: int pipe(int f ...
- IPC 进程间通信方式——管道
进程间通信概述 数据传输:一个进程需要将它的数据发送给另一个进程,发送的数据量在一个字节到几兆字节之间 共享数据:多个进程想要操作共享数据,一个进程对共享数据的修改,别的进程应该立刻看到. 通知时间: ...
- Linux IPC实践(1) -- 概述
进程的同步与互斥 进程同步: 多个进程需要相互配合共同完成一项任务. 进程互斥: 由于各进程要求共享资源,而且有些资源需要互斥使用,因此各进程间竞争使用这些资源,进程的这种关系为进程的互斥;系统中某些 ...
随机推荐
- Android 通过系统使用NotificationListenerService 监听各种Notification的用法
NotificationListenerService是通过系统调起的服务,当有应用发起通知的时候,系统会将通知的动作和信息回调给NotificationListenerService. 在继承Not ...
- NET 项目结构搭建
NET 项目结构搭建 我们头开始,从简单的单项目解决方案,逐步添加业务逻辑的约束,从应用逻辑和领域逻辑两方面考虑,从简单的单个项目逐步搭建一个多项目的解决方案.主要内容:(1)搭建应用逻辑和领域逻辑都 ...
- android下调试声卡驱动之概述
在Android中音频系统使用的是ALSA系统架构.ASoC--ALSA System on Chip .是建立在标准ALSA驱动层上,为了更好地支持 嵌入式处理器和移动设备中的音频Codec的一套软 ...
- 开展:随笔记录 OSGI的jar增加了一些小问题和注意事项
在引用jar当包,假设引用的项目包.在需要MANIFEST.MF 它定义 一.外用jar: 实例:外部参考需要包装的Import package里面 定义一下.如:google-gson-2.2.2. ...
- Git打补丁常见问题
Git打补丁常见问题 往往觉得得到某个功能的补丁就觉得这个功能我就已经成功拥有了,可是在最后一步的打补丁的工作也是须要相当慎重的,甚至有可能还要比你获取这个补丁花费的时间还要多.看到好多同行遇到这个问 ...
- Lua 脚本语法说明(转)
Lua脚本语法说明(增加lua5.1部份特性) Lua 的语法比较简单,学习起来也比较省力,但功能却并不弱. 所以,我只简单的归纳一下Lua的一些语法规则,使用起来方便好查就可以了.估计看完了,就懂得 ...
- Swing之JTable的详细介绍(转)
表格(Table)的使用与介绍8-1:使用JTable组件:类层次结构图:java.lang.Object--java.awt.Component--java.awt.Container--javax ...
- PowerDesigner创建物理模型
原文:PowerDesigner创建物理模型 Using PowerDesigner Create PDM 1.打开PowerDesigner 按Ctrl+N 创建物理模型 2.创建后修改名称,并在工 ...
- 在投票系统方法的原则刷票(突破ip限制刷票PHP版)
让我谈一点:事实上,没有一个突破ip限制,因为实际上,,这项限制server结束,client牛逼,不能突破..只要是能够始终重复刷票罢了 一个朋友突然来了个网站,让我帮她投票..我是一个更好的人说话 ...
- Xcode_6.3_beta_4 官方 下载地址
http://adcdownload.apple.com//Developer_Tools/Xcode_6.3_beta_4/Xcode_6.3_beta_4.dmg