是否有可能使用c ++(stl)使用stream从命名pipe道(mkfifo)读取 – 因此不会事先为读取操作定义char *buffer[MAX_SIZE] ?
我想读取,直到缓冲区结束并把结果放入std::string 。
(当前方法: bytes = read(fd,buffer,sizeof(buffer));事先要求分配某种缓冲区。
防止Windows在parsingdll依赖项时使用PATH envvariables?
对于C ++应用程序,什么可能导致HP-UX和LINUX的返回值有所不同?
如何指定configure脚本的include目录
使用Allegro-5从Linux进行交叉编译到Windows
启用和禁用USB端口
将文件保存到networking
在Linux中find会话负责人或进程组的控制TTY的方法是什么?
需要math库的序列/范围的操作
有没有免费的Windowsdebugging器允许向后步进与C + +
用mkfifo创建的命名管道就像普通文件一样。 因此可以使用std::ifstream和std::ofstream来访问它们:
#include <fstream> #include <iostream> int main(int,char** argv) { std::ifstream file{argv[1]}; std::string line; std::getline(file,line); std::cout << line << 'n'; }
跑:
mkfifo foobar ./main foobar
和其他地方:
echo 'Hello World!' > foobar
…这将导致./main打印“Hello world!”到标准输出。
有没有什么神奇的管道到你的程序它只是把你的cin阅读从流而不是从控制台的用户输入: Linux终端管道到我的C + +程序
简单地看一下这个问题的编辑历史,就会发现这个问题已经从它的原始版本中得到了很大的改进,这要归功于康拉德·鲁道夫 ( Konrad Rudolph) (在这个问题上的另一个回答者)。在一个进一步的卑鄙行为中,我将去掉他的两个解决方案潺潺流水string :
const string mkfifo{ istreambuf_iterator<char>(cin),istreambuf_iterator<char>() };
stringbuf复制方法:
istringstream temp; temp << cin.rdbuf(); const auto mkfifo = temp.str();
你可以阅读各自职位的优缺点。 要使用这个代码,说你编译的程序被命名为main你可以像这样管道化它:
mkfifo named_pipe echo "lorem ipsum" > named_pipe ./main named_pipe
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。