gpt4 book ai didi

c++ - 为什么tail -f 取不到数据?

转载 作者:太空狗 更新时间:2023-10-29 23:09:18 24 4
gpt4 key购买 nike

在我的程序中,我将子进程的输出重定向到管道,并在父进程中获取此结果并执行某些操作(这并不重要)。但是当我使用 tail -f test.txt 命令时我的程序不工作并且在 tail 运行期间没有收到任何数据,并且只有在 tail 完成(或被杀死)后才获取这些数据).

起初我以为问题是 tail -f 没有刷新,这就是为什么我无法收到任何数据,但是当我尝试重定向 tail -f 的输出时 对于某些文件,即使 tail 未完成,数据也在此文件中。

//the code of creating child and redirecting data (important part)
//only core is here so please don't tell me that maybe pipe() or fork() is failed

pid_t pid;
int outpipe[2]; //pipe for reading from stdout
int errpipe[2]; //pipe for reading from stderr

// Createing pipes for childs stdout and stderr streams
pipe(outpipe);
pipe(errpipe);
pid = fork();
if(pid == 0)
{
// This is the child process. Closing read end of pipes and duplicating stdout and stderr streams
close(outpipe[0]);
dup2(outpipe[1], STDOUT_FILENO);
close(errpipe[0]);
dup2(errpipe[1], STDERR_FILENO);

if(execvp(argv[0], (char * const *)argv) == -1)
{
fprintf(stderr, "Failed to execute command %s: %s", argv[0], strerror(errno));
_exit(EXIT_FAILURE);
}

_exit(EXIT_SUCCESS);
}
else if (pid != -1)
{
// This is the parent process, Closing write end of pipes and opening fds as FILE
close(outpipe[1]);
*child_stdout_stream=fdopen(outpipe[0], "rt");
close(errpipe[1]);
*child_stderr_stream=fdopen(errpipe[0], "rt");
*child_pid=pid;
}

然后我从 child_stderr_streamchild_stdout_stream 中读取它们作为参数传递以运行上面的部分来自什么。对于阅读,我使用 select() 在从其中一个流中读取之前不阻止程序。


添加部分select and read

int select_and_read(FILE **files, bool *is_eof, char *chars, int *mask, int nfiles, int timeout, pid_t child_pid)
{
int max_fd_plus_1 = 0;
fd_set rfds;
struct timeval tv;

FD_ZERO(&rfds);

for(int i = 0; i < nfiles; ++i)
{
if(is_eof[i]==false)
{
FD_SET(fileno(files[i]), &rfds);
max_fd_plus_1 = (max_fd_plus_1 > fileno(files[i])) ? max_fd_plus_1 : fileno(files[i]);
}
}
++max_fd_plus_1;

tv.tv_sec = timeout / 1000;
tv.tv_usec = (timeout % 1000) * 1000;

int retval = select(max_fd_plus_1, &rfds, NULL, NULL, &tv);
if(retval > 0)
{
*mask = 0;
for(int i = 0; i < nfiles; ++i)
{
if(is_eof[i]==false)
{
if(FD_ISSET(fileno(files[i]), &rfds))
{
*mask |= 1 << i;
chars[i] = fgetc(files[i]);
}
}
}
}
else
{
kill(child_pid, SIGKILL);
}
return retval;
}

最佳答案

这个奇怪的问题解决的很奇怪。我刚刚通过这种方式将文件缓冲区设置为 0:

else if (pid != -1)
{
// This is the parent process, Closing write end of pipes and opening fds as FILE
close(outpipe[1]);
*child_stdout_stream=fdopen(outpipe[0], "rt");
setbuf(*child_stdout_stream, NULL);
close(errpipe[1]);
*child_stderr_stream=fdopen(errpipe[0], "rt");
setbuf(*child_stderr_stream, NULL);
*child_pid=pid;
}

这很奇怪,这有帮助,但无论如何我的程序现在运行良好。

关于c++ - 为什么tail -f 取不到数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5679006/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com