pipe函数详解

pipe函数详解

转载地址:http://blog.chinaunix.net/uid-24004458-id-335420.html

相关函数  mkfifo,popen,read,write,fork

mkfifo函数的作用是在文件系统中创建一个文件,该文件用于提供FIFO功能,即命名管道。
前边讲的那些管道都没有名字,因此它们被称为匿名管道,或简称管道。对文件系统来说,
匿名管道是不可见的,它的作用仅限于在父进程和子进程两个进程间进行通信。而命名管道是
一个可见的文件,因此,它可以用于任何两个进程之间的通信,不管这两个进程是不是父子进程,
也不管这两个进程之间有没有关系
#include <sys/types.h>
#include <sys/stat.h>
int mkfifo( const char *pathname, mode_t mode );
mkfifo函数需要两个参数,第一个参数(pathname)是将要在文件系统中创建的一个专用文件。
第二个参数(mode)用来规定FIFO的读写权限。Mkfifo函数如果调用成功的话,返回值为0;
如果调用失败返回值为-1

popen使用FIFO管道执行外部程序。
#include <stdio.h>
FILE *popen(const char *command, const char *type);
popen 通过type是r/w确定command的输入/输出方向,r和w是相对command的管道而言的。
r表示command从管道中读入,w表示 command通过管道输出到它的stdout,
popen返回FIFO管道的文件流指针。pclose则用于使用结束后关闭这个指针。


表头文件  #include<unistd.h>
定义函数  int pipe(int filedes[2]);


函数说明  pipe()会建立管道,并将文件描述词由参数filedes数组返回。filedes[0]为管道里的读取端,filedes[1]则为管道的写入端。

返回值  若成功则返回零,否则返回-1,错误原因存于errno中。

错误代码  EMFILE 进程已用完文件描述词最大量。
ENFILE 系统已无文件描述词可用。
EFAULT 参数filedes数组地址不合法。
发布了156 篇原创文章 · 获赞 92 · 访问量 202万+
展开阅读全文

Linux下pipe()未包含头文件却提示重名问题

11-18

(C++)在Windows下可以正常工作的程序,在Linux下无法编译,提示类型未声明。但在此之前我已经声明了名为“pipe”的类,并且添加了构造器。经过查询得知pipe重名,但并未包含有“pipe”的头文件。请问各位大神能否给我一个解释?我的教练拒绝回答我。理由是他不喜欢C++! #include <fstream> #include <cstdlib> using namespace std; ifstream cin("bird.in"); ofstream cout("bird.out"); struct pipe { int P; int L; int H; pipe(){P = L = H = -1;} }; int up[10004] = {0},down[10004] = {0},n,m,k; int nowx = 0,nowy = 0; int point = 0; int min_p = 50000; int max_pipe = 0; int cross = 0; pipe Pi[10004]; int fly() //检查下一位置可否飞越 { if(nowx==n&&nowy>0) //返回递归调用(到达终点) { if(min_p>point) min_p = point; return 1; } int i; bool out = false; bool is_find = false; int back = 0; for(i = 1;!out;i++) //点击 { nowy = nowy + up[nowx] * i; nowx++; point += i; if(nowy>=m) back = nowy - m,nowy = m,out = true; if(Pi[nowx].P != -1) //下一个位置上有管道 { if(Pi[nowx].L>=nowy||Pi[nowx].H<=nowy) //当前点击次数无法飞越 { if(max_pipe<cross) max_pipe = cross; if(!out) { nowx--; //回溯 nowy -= up[nowx] * i; //回溯 } else { nowx--; nowy = nowy + back; nowy = nowy - up[nowx] * i; } point -= i; //回溯 continue; //下一次循环 } else { cross++; int r = fly(); //检查下一位置 if(r==1) is_find = true; cross--; } } else //下一个位置上无管道 { int r = fly(); //检查下一位置 if(r==1) is_find = true; //可以飞越 if(!out) { nowx--; //回溯 nowy -= up[nowx] * i; //回溯 } else { nowx--; nowy = nowy + back; nowy = nowy - up[nowx] * i; } point -= i; //回溯 } } nowy = nowy - down[nowx]; //不点击 if(nowy<=0) { nowy += down[nowx]; if(is_find) return 1; return 0; } nowx++; if(Pi[nowx].P != -1) //下一个位置上有管道 { if(Pi[nowx].L>=nowy||Pi[nowx].H<=nowy) //下落无法飞越 { if(max_pipe<cross) max_pipe = cross; } else { cross++; int r = fly(); //检查下一位置 if(r==1) is_find = true; cross--; } } else //下一个位置上无管道 { int r = fly(); //检查下一位置 if(r==1) is_find = true; //可以飞越 } nowx--; nowy = nowy + down[nowx]; if(is_find) return 1; return 0; } int main() { int i; cin >> n >> m >> k; for(i = 0;i < n;i++) cin >> up[i] >> down[i]; for(i = 0;i < k;i++) { int temp; cin >> temp; cin >> Pi[temp].L >> Pi[temp].H; Pi[temp].P = 1; } int ans = 0,temp = 0; for(i = 1;i <= m;i++) { nowx = 0; nowy = i; point = 0; temp = fly(); if(temp == 1) ans = 1; } if(ans==0) cout << 0 << endl << max_pipe; else cout << 1 << endl << min_p; cin.close(); cout.close(); return 0; } 问答

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览