我是C语言的新手,今天,当我尝试关闭使用popen函数创建的"Open Stream"时,我遇到了一个问题。 1.由于我在此程序中使用的轮询功能,是否出现了此问题? 2. 还是因为 fcntl 功能?如果有人教我这个问题的确切原因,我会很高兴。我附上下面的代码示例,请看一下。
代码示例:
#include <stdio.h>
#include <stdlib.h>
#include <poll.h>
#include <fcntl.h>
char line[1024];
FILE *tfd;
int readData(int *fd)
{
struct pollfd pfd;
int pollTime = 10000;
pfd.events = POLLIN;
pfd.fd = *fd;
int ret=1;
ret = poll(&pfd,1,pollTime);
printf("nAfter ret=%dn.",ret);
if(ret == -1 || ret ==0)
{
printf("Couldn't poll returned : %dn", ret);
return 0;
} else {
if( fgets(line,sizeof(line),tfd) == NULL )
{
printf("nReturns nothing.");
return 0;
}
printf("nRead Some data.");
}
return ret;
}
void main(void)
{
int ret;
int fd, flags;
char filepath[] = "/home/TEST/";
char filename[] = "log.txt";
char cmd[100];
sprintf(cmd,"tail -f %s%s",filepath, filename);
tfd = popen(cmd, "r");
fd = fileno(tfd);
flags = fcntl(fd, F_GETFL, 0);
flags |= O_NONBLOCK;
fcntl(fd, F_SETFL, flags);
if(tfd==NULL)
{
printf("npopen failed, exiting.n");
exit(0);
}
while( (ret=readData(&fd)) > 0 )
{
printf("nret2=%d.",ret);
printf("nLine : %s",line);
}
printf("n**********DONE****************.n");
pclose(tfd);
}
输出:
[root@localhost TEST]# ./polltail
After ret=1
.
Read Some data.
ret2=1.
Line : 64 bytes from maa03s05-in-f4.1e100.net (74.125.236.68): icmp_req=31 ttl=52 time=38.4 ms
After ret=0
.Couldn't poll returned : 0
**********DONE****************.
在这里,我期待提示出现在执行结束时。但是,它不会到来。
你得到一个超时,因为 tail 在 10 秒内没有产生任何输出。然后你调用 pclose() ,但是,这就是文档对 pclose() 的描述。
pclose() 函数等待关联的进程终止,并返回 wait4(2) 返回的命令的退出状态。
tail 命令仍在运行,并且将继续运行,直到有人杀死它,因此 pclose() 将无限期地阻止它。如果你需要你的程序来终止你正在运行的 tail 命令,你需要另一种方法,而不是使用 popen/pclose。
-f 选项导致文件末尾时尾部不停止已到达,而是等待附加其他数据输入。 如果标准输入为管道,但如果它是FIFO,则不行。
pclose() 函数等待关联的进程终止;它返回命令的退出状态,由 Wait4(2) 返回。
pclose() 函数返回 -1 如果流未与"popen"命令,如果流已经"关闭",或者如果 wait4(2)返回错误。
检查 pclose() 的返回值。