C++ inotify_add_watch在没有此类文件或目录的情况下失败

C++ inotify_add_watch在没有此类文件或目录的情况下失败,c++,c,amazon-ec2,ubuntu-16.04,inotify,C++,C,Amazon Ec2,Ubuntu 16.04,Inotify,我试图在我的c/c++程序中观察文件的创建。我正试图使用inotify来达到这个目的。然而,当我在我的代码中调用时,我没有得到这样的文件或目录。我正在Ubuntu 16.04机器上运行我的程序。机器正在EC2云中运行。有人能告诉我没有收到此类文件或目录错误的可能原因吗 根据的手册页,这甚至不是一个可能的错误代码。我已确保我对试图监视的文件具有正确的读取权限等 这是我的测试程序: #include <stdio.h> #include <stdlib.h> #include

我试图在我的c/c++程序中观察文件的创建。我正试图使用inotify来达到这个目的。然而,当我在我的代码中调用时,我没有得到这样的文件或目录。我正在Ubuntu 16.04机器上运行我的程序。机器正在EC2云中运行。有人能告诉我没有收到此类文件或目录错误的可能原因吗

根据的手册页,这甚至不是一个可能的错误代码。我已确保我对试图监视的文件具有正确的读取权限等

这是我的测试程序:

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/inotify.h>
#include <limits.h>

#define MAX_EVENTS  1024
#define LEN_NAME    16
#define EVENT_SIZE  (sizeof (struct inotify_event))
#define BUF_LEN     (MAX_EVENTS * (EVENT_SIZE + LEN_NAME))

int
main(int argc, char **argv)
{
  int length, i = 0, wd;
  int fd;
  char buffer[BUF_LEN];

  /* Initialize Inotify*/
  fd = inotify_init();
  if (fd < 0) {
    perror("Couldn't initialize inotify");
  }

  /* add watch to starting directory */
  wd = inotify_add_watch(fd, argv[1], IN_CREATE | IN_MODIFY | IN_DELETE);

  if (wd == -1) {
      printf("Couldn't add watch to %s. errno=%d\n", argv[1], errno);
      return -1;
  } else {
      printf("Watching:: %s\n",argv[1]);
  }

  /* do it forever*/
  while (1) {
    i = 0;
    length = read(fd, buffer, BUF_LEN);

    if (length < 0) {
      perror("read");
    }

    while (i < length) {
      struct inotify_event *event = (struct inotify_event *) &buffer[i];
      if (event->len) {
        if (event->mask & IN_CREATE) {
          printf("Create event. file=%s, wf=%d\n", event->name, event->wd);
        }

        if (event->mask & IN_MODIFY) {
          printf("Modify event. file=%s, wf=%d\n", event->name, event->wd);
        }

        if (event->mask & IN_DELETE) {
          printf("Delete event. file=%s, wf=%d\n", event->name, event->wd);
        }

        i += EVENT_SIZE + event->len;
      }
    }
  }

  /* Clean up*/
  inotify_rm_watch(fd, wd);
  close(fd);

  return 0;
}
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#定义最大事件数1024
#定义LEN_名称16
#定义事件大小(sizeof(结构索引事件))
#定义基本长度(最大事件*(事件大小+长度名称))
int
主(内部argc,字符**argv)
{
整数长度,i=0,wd;
int-fd;
字符缓冲区[BUF_LEN];
/*初始化Inotify*/
fd=inotify_init();
如果(fd<0){
perror(“无法初始化inotify”);
}
/*将监视添加到起始目录*/
wd=inotify_add_watch(fd,argv[1],IN_CREATE | IN|u MODIFY | IN_DELETE);
如果(wd==-1){
printf(“无法将手表添加到%s。错误号=%d\n”,argv[1],错误号);
返回-1;
}否则{
printf(“监视::%s\n”,argv[1]);
}
/*永远这样做*/
而(1){
i=0;
长度=读取(fd、缓冲区、BUF_LEN);
如果(长度<0){
佩罗(“阅读”);
}
while(i镜头){
如果(事件->掩码和创建中){
printf(“创建事件。文件=%s,wf=%d\n”,事件->名称,事件->wd);
}
如果(事件->屏蔽和修改){
printf(“修改事件。文件=%s,wf=%d\n”,事件->名称,事件->wd);
}
如果(事件->屏蔽和删除中){
printf(“删除事件。文件=%s,wf=%d\n”,事件->名称,事件->wd);
}
i+=事件大小+事件->镜头;
}
}
}
/*清理*/
inotify_rm_手表(fd、wd);
关闭(fd);
返回0;
}

如果要监视文件/目录的创建,则应监视父目录,因为调用
inotify\u add\u watch()
时新文件/目录不存在。
然后,当在监视目录中创建任何文件/目录时,您将获得一个事件,新的文件/目录名称将位于事件->名称中。

“这甚至不是可能的错误代码之一”再次检查<代码>事件。我的错,忽略了这一点。然而,问题仍然存在。不管我走哪条路,我都会得到同样的错误。即使是像'a.out a.txt'这样的简单测试也会出现这种错误。路径存在吗?是的。正如我所提到的,即使是像“a.out my.txt”这样的简单测试,如果我正在监视的文件与程序位于同一目录中,我也会遇到这个错误/a、 这个也失败了吗?