我是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=%d\n.",ret);
if(ret == -1 || ret ==0)
{
printf("Couldn't poll returned : %d\n", 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****************.
这里我希望在执行结束时出现提示。但是,它不会到来。
答案 0 :(得分:1)
你正在超时,因为尾巴在10秒内没有产生任何输出。然后你调用pclose(),然而,这就是文档中关于pclose()的内容。
pclose()函数等待关联的进程终止并返回wait4(2)返回的命令的退出状态。
tail命令仍在运行,并且将继续执行,直到有人杀死它,因此pclose()将无限期地阻塞。如果您需要程序来终止正在运行的tail命令,那么除了使用popen / pclose之外,还需要另一种方法。
答案 1 :(得分:1)
-f选项导致tail在文件结尾时不会停止 达到了,而是等待追加额外的数据 输入。如果标准输入是a,则忽略-f选项 管道,但如果它是FIFO,则不行。
pclose()函数等待关联的进程终止;它 返回命令的退出状态,由wait4(2)返回。
如果stream与a没有关联,则pclose()函数返回-1 “popened”命令,如果流已经“pclosed”,或者wait4(2) 返回错误。
检查pclose()的返回值。