linux – 如何监视文件描述符以获得新数据的可用性?
发布时间:2020-12-13 23:08:27 所属栏目:Linux 来源:网络整理
导读:请考虑以下代码段. #include fcntl.h#include stdio.h#include sys/poll.h#include unistd.hint main(int argc,char ** argv) { int fd; char buf[1024]; int i; struct pollfd pfds; fd = open(argv[1],O_RDONLY); while (1) { pfds.fd = fd; pfds.events =
请考虑以下代码段.
#include <fcntl.h> #include <stdio.h> #include <sys/poll.h> #include <unistd.h> int main(int argc,char ** argv) { int fd; char buf[1024]; int i; struct pollfd pfds; fd = open(argv[1],O_RDONLY); while (1) { pfds.fd = fd; pfds.events = POLLIN; poll(&pfds,1,-1); if (pfds.revents & POLLIN) { i = read(fd,buf,1024); write(1,i); } } return 0; } 该程序接收文件名,打开相应的文件,并“轮询”其文件描述符,以便监视可用性中的数据.每当轮询检测到可用性数据时,都会打印这些新数据. 但是,这个程序会发生什么?如果我要监视的文件在程序启动时已包含数据,则打印其内容.没关系.但是,稍后,当我使用文本编辑器编辑文件并保存它时,我的程序不会打印新数据. 那么,如何监视常规文件描述符(不是使用其路径的文件)以获得新的数据可用性?我是否必须使用民意以外的其他功能?或者我错过任何pollfd旗帜? 解决方法
您不能在常规文件上使用poll来监视更改.但是,还有其他几种方法.经典方法是使用打开的文件描述符定期调用fstat,并将返回的字段与先前的字段(特别是st_size)进行比较.现代方法是使用inotify(7)来监视文件.例如,最近版本的GNU tail使用这种方法:
$strace tail -f /tmp/foobar ... open("/tmp/foobar",O_RDONLY) ) = 3 ... inotify_init() = 4 inotify_add_watch(4,"/tmp/foobar",IN_MODIFY|IN_ATTRIB|IN_DELETE_SELF|IN_MOVE_SELF) = 1 ... read(4,... 有关其工作原理的详细信息,请参见手册第inotify(7)页. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |