1.标准流管道

管道操作支持文件流模式,用来创建链接还有一个进程的管道,通过函数popen和pclose
popen的详细介绍在本blog:Linux
多进程学习
中有具体介绍

2.无名管道(PIPE)

特点:
1)仅仅能在亲缘关系进程间通信(父子或兄弟)
2)半双工(固定的读端和固定的写端)
3)是特殊文件,能够用read,write等,在内存中
管道函数原型:
#include<unistd.h>
int pipe(int fds[2]);
管道在程序中用一对文件描写叙述符表示,一个是可读属性,一个是可写属性:fds[0]读,fds[1]写
两个进程必须有继承关系,才干继承这对打开的文件描写叙述符

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文件

创建FIFO文件与创建普通文件非常类似,仅仅是创建之后的文件FIFO
创建FIFO文件的函数原型
#include<sys/types.h>
#include<sys/stat.h>
int mkfifo(const char *pathname,mode_t mode);
參数pathname为要创建的FIFO文件的全路径名;
參数mode为文件的訪问权限
创建成功返回0,创建失败为-1
删除FIFO文件的函数原型为
int unlink(const char *pathname);
样例:
#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文件

对于FIFO类型的文件的打开/关闭更普通文件一样,都是用open和close函数。用O_WRONLY打开FIFO的写入端,用O_RDONLY选项,则打开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

读:
fd_recv=open(argv[1],O_RDONLY);
char buf_recv[1024]="";
if(read(fd_recv,buf_recv,1024)!=0)   write(1,buf_recv,strlen(buf_recv));
close (fd_recv)
写:
fd_send=open(argv[2],O_WRONLY);
char buf_send[1024]="";
if(fgets(buf_send,1024,stdin)!=NULL) write(fp_send,buf_send,strlen(buf_send));
close(fd_send);
程序示范:
pork_send.c与pork_recv.c聊天
使用fork开辟留一个进程,两个程序能够进行聊天功能

/*************************************************************************
> 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,进程间通信)之管道学习的更多相关文章

  1. Linux进程间通信之管道

    1,进程间通信 (IPC ) Inter-Process Communication 比较好理解概念的就是进程间通信就是在不同进程之间传播或交换信息. 2,linux下IPC机制的分类:管道.信号.共 ...

  2. linux内核剖析(八)进程间通信之-管道

    管道 管道是一种两个进程间进行单向通信的机制. 因为管道传递数据的单向性,管道又称为半双工管道. 管道的这一特点决定了器使用的局限性.管道是Linux支持的最初Unix IPC形式之一,具有以下特点: ...

  3. Linux进程间通信(一) - 管道

    管道(pipe) 普通的Linux shell都允许重定向,而重定向使用的就是管道. 例如:ps | grep vsftpd .管道是单向的.先进先出的.无结构的.固定大小的字节流,它把一个进程的标准 ...

  4. linux IPC总结——管道

    管道 管道是unix ipc的最古老形式,是一种在内存中的特殊文件,只能在具有公共祖先的进程之间使用(即父子进程,兄弟进程). 管道由pipe函数创建 #include <unistd.h> ...

  5. 【IPC第二个进程间通信】管道Pipe

    IPC进程间通信+管道Pipe                IPC(Inter-Process Communication,进程间通信).         管道用于进程间共享数据,事实上质是共享内存 ...

  6. Linux - 进程间通信 - 匿名管道

    一.概念:进程间通信( IPC,InterProcess Communication) 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进城之间要交换数据必须通过内 ...

  7. Linux 进程间通信之管道(pipe),(fifo)

     无名管道(pipe) 管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信: 定义函数: int pipe(int f ...

  8. IPC 进程间通信方式——管道

    进程间通信概述 数据传输:一个进程需要将它的数据发送给另一个进程,发送的数据量在一个字节到几兆字节之间 共享数据:多个进程想要操作共享数据,一个进程对共享数据的修改,别的进程应该立刻看到. 通知时间: ...

  9. Linux IPC实践(1) -- 概述

    进程的同步与互斥 进程同步: 多个进程需要相互配合共同完成一项任务. 进程互斥: 由于各进程要求共享资源,而且有些资源需要互斥使用,因此各进程间竞争使用这些资源,进程的这种关系为进程的互斥;系统中某些 ...

随机推荐

  1. HQApi命令行接口配置

    执行的命令行前准备 在您的个人文件夹中第一次创建 型材client.properties 如下面 cd C:\Users\scnyli\ mkdir ".hq" 创建一个 clie ...

  2. [置顶] ffmpg简介以及用它实现音频视频合并(java)

    1.简介     FFmpeg是一个自由软件,可以运行音频和视频多种格式的录影.转档.流功能. 2.下载     源代码 git://git.libav.org/libav.git     Windo ...

  3. java.lang.RuntimeException: Method called after release()

    主要引起是因為在 camera.stopPreview();   camera.release(); 前沒有將setPreviewCallback 設置為null, 解決情況: public void ...

  4. Android4.0设置接口变更摘要(四)

    为了与你之前,你已经设置了共享Tab风格和Item实现圆角.希望能给有须要的朋友一点点帮助,今天再和大家分享一下用ViewPager实现设置分页,小米和OPPO就是这种设置,先来看看效果图: wate ...

  5. Struts的ONGL

    1.什么是OGNL OGNL它是Object Graphic Navigation Language(对象图导航语言)缩写,    它是一个开源项目. Struts2框架使用OGNL作为默认的表达式语 ...

  6. mapreduce程序来实现分类

    文件的内容例如以下所看到的: 5 45 8 876 6 45 要求最后的输出格式: 1    5 2    6 3    8 4    45 5    45 5    876 首先,这个题目是须要对文 ...

  7. Python在信号与系统(1)——Hilbert兑换,Hilbert在国家统计局的包络检测应用,FIR_LPF滤波器设计,格鲁吉亚也迫使高FM(PM)调制

    谢谢董老师,董老师是个好老师. 心情久久不能平静,主要是高频这门课的分析方法实在是让我难以理解,公式也背只是,还是放放吧. 近期厌恶了Matlab臃肿的体积和频繁的读写对我的Mac的损害,所以学习了一 ...

  8. Cocos2d-x3.0游戏实例《不要救我》三——背景滚动周期

    好.让我们来解释一下这个无限循环滚动的背景.这方面的知识一直讲到烂.我以前的文章还介绍了.所以不是那么特别清楚. 笨木头花心贡献,啥?花心?不呢,是用心~ 转载请注明,原文地址:http://www. ...

  9. 【iOS发展-61】更换plist经过资源,执行iOS一旦数据仍显示在模拟器的外观,如何解决?

    (1)案例介绍 --我们首先导入plist文件做项目,模拟的观看效果. --删除plist,更换一个新的plist,CMD+R模拟执行,或者找到该程序界面上显示最后一个数据. (2)原因 是由于第一次 ...

  10. C++使用对象指针

    //定义结构 Box.h: #ifndef BOX_H #define BOX_H struct Box{ double length; double width; double height; do ...