mkstemp()
函数从模板生成唯一的临时文件名,创建并打开文件,并返回文件的打开文件描述符。模板的最后六个字符必须是“XXXXXX”,并且这些字符将替换为使文件名唯一的字符串。由于它将被修改,因此模板不能是字符串常量,而应该声明为字符数组。
将模板替换为使文件名唯一的字符串后,我保存字符串以供以后使用。这是我遇到一个奇怪的问题,我似乎无法绕过我的脑袋。我可以将正确的文件名打印到我的终端,查看我的文件资源管理器中的文件并打开它以查看正确的内容,但是当我将字符串作为命令的一部分包含在popen()
执行时,我得到一个指向一个空文件。当我将临时文件的名称硬编码回我的代码然后再次运行时,我得到了我期望的正确结果。我有什么东西可以忽略或丢失吗?这是一段代码:
char tmpname[] = "tmp.XXXXXX";
FILE *fpt = fdopen(mkstemp(tmpname), "w");
string saved_tmpname(tmpname);
// blah
// write to file
// blah blah
const string command = "mycommand " + saved_tmpname;
cout << command << endl; // prints correctly
FILE *fpipe = popen(command.c_str(), "r");
if (fpipe == NULL) {
perror(command.c_str());
}
char buff[4096];
while (fgets(buff, 4096, fpipe)) {
// we don't get here!
}
答案 0 :(得分:4)
来自mkstemp
的联机帮助页:
使用open(2) O_EXCL 标志打开文件,保证调用者是创建文件的进程。
O_EXCL 标志会阻止您再次打开该文件。这没关系,因为它是一个临时文件 - 只有一个进程(创建者)应该有权访问它。临时文件有时会包含敏感数据。