我正在尝试从Qt应用程序写入新创建的QProcess。 Qt文档告诉我创建一个进程并使用:: write()函数写入新进程的标准输入。它没有用,所以我在一个带有std :: cin和stdin流的程序中尝试了一些基本的测试。
当我在main()中启动普通程序时,我会这样做:
int result = fseek(stdin, 0, SEEK_END); // result is -1, indicating error
result = ftell(stdin); // result is 0
使用C ++ std :: istream我做:
std::cin.seekg(0, std::ios::end); // Or std::ios_base::end
int result = std::cin.tellg(); // Returns -1
bool isgood = std::cin.good(); // Returns false
我真的很困惑。首先我想知道std :: cin和stdin是否都是相同的流,那是标准输入?一个是std :: istream对象,另一个是我的Visual Studio上的FILE typedef,_ iobuf。
我很确定寻找到流的末尾不会设置错误位或EOF位,因为人们使用此方法寻找到最后,获取文件的大小然后寻求回到0无需清除()错误标志。
我被告知的两行fseek(stdin,0,SEEK_END)和ftell(stdin)可用于检查标准输入是否为空,但fseek()返回-1错误。 我认为这是我的系统的一个问题,但我尝试了一个在线C ++编译器,我得到了相同的结果,唯一的区别是在线编译器返回-1为ftell(stdin)而不是我的Visual Studio,返回0。
我无法从我的qt应用程序写入标准输入,但是,我可以将stdin重定向到我的硬盘驱动器上的文件,这确实有效。帮助将不胜感激。
答案 0 :(得分:2)
我会尝试从标准输入读取Qt方式,例如
#include <QApplication>
#include <QFile>
#include <QTextStream>
#include <QMessageBox>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QFile in;
in.open(stdin, QFile::ReadOnly);
QTextStream stream(&in);
QString line;
while(true)
{
line = stream.readLine();
if(!line.isEmpty())
{
QMessageBox::about(0, "stdin", line);
}
}
}
您可以使用QProcess
:
#include <QCoreApplication>
#include <QProcess>
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
QProcess process;
process.start("/full/path/to/the/receiver/application");
if(process.waitForStarted())
{
process.write("Hello\n");
}
return a.exec();
}
为了完整起见,这也可以在读者方面起作用:
#include <QApplication>
#include <QMessageBox>
#include <iostream>
#include <string>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
std::string line;
while(true)
{
std::getline(std::cin, line);
QString data(line.c_str());
if(!data.isEmpty())
{
QMessageBox::about(0, "stdin", data);
}
}
}