epoll模型添加inotify事件的代码实现

#include <sys/inotify.h>
#include <sys/epoll.h>
#include <stdlib.h>
#include <stdio.h>
#include <sys/ioctl.h>
#include <string.h>
struct inotify_data_type{
    int fd;
    char self_type[16];
};

int main(int argc,char* argv[]){
    if(argc < 2) {
        return 1;
    }
    int inotify_fd = inotify_init();
    if(inotify_fd < 0){
        printf("Create inotify descriptor failed.");
        return 1;
    }
    int *wd = malloc(sizeof(int)*(argc-1));
    int i;
    for(i = 1; i < argc; i++){
        wd[i-1] = inotify_add_watch(inotify_fd,argv[i],IN_CLOSE_WRITE);
        if(wd[i-1] < 0){
            printf("Could not watch dirctory : %s");
            return 1;
        }
    }
    int nb = 1;
    ioctl(inotify_fd,FIONBIO,&nb);

    int epoll_fd = epoll_create(1024);
    if(epoll_fd < 0){
        printf("Create epoll descriptor failed");
        return 1;
    }

    struct inotify_data_type inotify_data;
    inotify_data.fd = inotify_fd;
    strcpy(inotify_data.self_type,"inotify");


    struct epoll_event inotify_event;
    int option = EPOLL_CTL_ADD;
    inotify_event.events = EPOLLIN|EPOLLET;
    inotify_event.data.ptr = &inotify_data;

    int result = epoll_ctl(epoll_fd, option, inotify_fd, &inotify_event);
    if(result < 0){
        printf("Could not add Inotify event in EPOLL");
        return 1;
    }

    int running = 1;
    struct epoll_event event_list[10];
    while(running){
        int events_num = epoll_wait(epoll_fd, event_list,10,0);
        if(events_num < 0){
            printf("Epoll_wait failed!");
            return 1;
        }

        if(events_num > 0){
        //  int i = 0;
            for(i = 0; i < events_num; i++){
                struct inotify_data_type *inotify_data_backup = event_list[i].data.ptr;
                if(strcmp(inotify_data_backup->self_type,"inotify") == 0){
                    int revents = event_list[i].events;
                    if(re
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用 epollinotify 监控文件,需要进行以下步骤: 1. 创建一个 epoll 实例并将其添加到监听文件描述符列表中。 2. 创建一个 inotify 实例并将其添加epoll 实例中。 3. 使用 inotify_add_watch 函数添加要监视的文件或目录。 4. 启动 epoll 循环,并等待事件发生。 5. 当有事件发生时,使用 epoll_wait 函数获取事件列表。 6. 遍历事件列表,处理每个事件。如果是 inotify 事件,则读取事件并处理它。 7. 如果需要继续监视文件,则重复步骤 4-6。 下面是一个简单的示例代码,用于监视目录中的文件创建或删除事件: ```c #include <stdio.h> #include <stdlib.h> #include <sys/epoll.h> #include <sys/inotify.h> #define MAX_EVENTS 10 #define EVENT_SIZE (sizeof (struct inotify_event)) #define BUF_LEN (MAX_EVENTS * (EVENT_SIZE + 16)) int main(int argc, char const *argv[]) { int fd, wd, epfd, n, i; char buf[BUF_LEN]; struct epoll_event event; struct epoll_event events[MAX_EVENTS]; // create an inotify instance fd = inotify_init(); if (fd < 0) { perror("inotify_init"); exit(EXIT_FAILURE); } // add the inotify instance to epoll epfd = epoll_create(1); if (epfd < 0) { perror("epoll_create"); exit(EXIT_FAILURE); } event.data.fd = fd; event.events = EPOLLIN | EPOLLET; if (epoll_ctl(epfd, EPOLL_CTL_ADD, fd, &event) < 0) { perror("epoll_ctl"); exit(EXIT_FAILURE); } // add directory to watch list wd = inotify_add_watch(fd, "/path/to/directory", IN_CREATE | IN_DELETE); if (wd < 0) { perror("inotify_add_watch"); exit(EXIT_FAILURE); } while (1) { // wait for events n = epoll_wait(epfd, events, MAX_EVENTS, -1); if (n < 0) { perror("epoll_wait"); break; } for (i = 0; i < n; i++) { if (events[i].data.fd == fd) { // read inotify events int len = read(fd, buf, BUF_LEN); if (len < 0) { perror("read"); break; } char *p = buf; while (p < buf + len) { struct inotify_event *event = (struct inotify_event *) p; printf("event: %s\n", event->name); p += sizeof(struct inotify_event) + event->len; } } } } // cleanup inotify_rm_watch(fd, wd); close(fd); close(epfd); return 0; } ``` 在此示例中,我们创建了一个 inotify 实例并将其添加epoll 实例中。然后,我们使用 inotify_add_watch 函数添加要监视的目录,并指定要监视的事件类型(在本例中为文件创建和删除事件)。最后,我们启动 epoll 循环,并等待事件发生。当事件发生时,我们读取 inotify 事件并处理它。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值