我下面的示例代码监视文件以进行修改。假设被监视的文件是 foo.txt,而从示例代码中得到的二进制名称是 inotify。我对示例代码进行了两次测试。
test1:
1) ./inotify foo.txt
2) echo "hello" > foo.txt
然后一切正常,并且“文件已修改”已打印出来。
test2:
1) ./infity foo.txt
2) vim foo.txt
3) 以某种方式编辑并保存,但不要退出 vim
打印出来的行是 未知的掩码 0x00008000,检查 inotify 头文件发现这个事件掩码意味着IN_CLOSE_WRITE .
从我的角度来看,“编辑和保存”只是menas修改。但显然 inotify 代码对它有不同的解释。对我来说很奇怪,任何人都可以帮助解释背后的事情吗?
#include <sys/inotify.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>
#include <stdlib.h>
int main(int argc, char **argv)
{
int fdnotify = -1;
if (argc !=2) {
fprintf(stderr, "usage: ./inotify dir_name\n");
exit(1);
}
printf("argc is %d\n", argc);
fdnotify = inotify_init();
if (fdnotify < 0) {
fprintf(stderr, "inotity_init failed: %s\n", strerror(errno));
}
int wd = inotify_add_watch(fdnotify, argv[1], IN_MODIFY);
if (wd < 0) {
fprintf(stderr, "inotify_add_watch failed: %s\n", strerror(errno));
}
while(1) {
char buffer[4096];
struct inotify_event *event = NULL;
int len = read(fdnotify, buffer, sizeof(buffer));
if (len < 0) {
fprintf(stderr, "read error %s\n", strerror(errno));
}
event = (struct inotify_event *) buffer;
while(event != NULL) {
if ((event->mask & IN_MODIFY) ) {
printf("File modified %s\n", event->name);
} else {
printf("unknown Mask 0x%.8x\n", event->mask);
}
len -= sizeof(*event) + event->len;
if (len > 0)
event = ((void *) event) + sizeof(event) + event->len;
else
event = NULL;
}
}
}