在Linux中,readdir
函數通常用于讀取目錄的內容,而不是直接用于文件監控。如果你想要實現文件監控,你可以使用其他機制,比如inotify
。inotify
是Linux內核提供的一種文件系統事件監控機制,它可以用來監控文件或目錄的變化,如打開、關閉、修改等。
以下是使用inotify
來實現文件監控的基本步驟:
包含必要的頭文件:
#include <sys/inotify.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
創建inotify實例:
int fd = inotify_init();
if (fd < 0) {
perror("inotify_init");
exit(EXIT_FAILURE);
}
添加監控:
使用inotify_add_watch
函數來添加你想要監控的文件或目錄。
int wd = inotify_add_watch(fd, "/path/to/directory", IN_MODIFY | IN_CREATE | IN_DELETE);
if (wd < 0) {
perror("inotify_add_watch");
close(fd);
exit(EXIT_FAILURE);
}
讀取事件:
使用read
函數來讀取inotify事件。
char buffer[4096];
ssize_t length = read(fd, buffer, sizeof(buffer));
if (length < 0) {
perror("read");
close(fd);
exit(EXIT_FAILURE);
}
解析事件:
解析buffer
中的數據來確定發生了哪些事件。
int i = 0;
while (i < length) {
struct inotify_event *event = (struct inotify_event *) &buffer[i];
if (event->len) {
if (event->mask & IN_CREATE) {
printf("File %s was created.\n", event->name);
}
if (event->mask & IN_DELETE) {
printf("File %s was deleted.\n", event->name);
}
if (event->mask & IN_MODIFY) {
printf("File %s was modified.\n", event->name);
}
}
i += sizeof(struct inotify_event) + event->len;
}
清理:
當不再需要監控時,使用inotify_rm_watch
來移除監控,并關閉文件描述符。
inotify_rm_watch(fd, wd);
close(fd);
請注意,上面的代碼只是一個簡單的示例,實際應用中可能需要更復雜的錯誤處理和事件處理邏輯。此外,inotify
有其限制,比如監控的文件描述符數量和事件隊列的大小,這些限制可以通過/proc/sys/fs/inotify/max_user_watches
和/proc/sys/fs/inotify/max_queued_events
來調整。