在Ubuntu系統中,inotify API是一組用于監控文件系統事件的接口。要使用inotify API,你需要包含相應的頭文件,并鏈接到正確的庫。以下是一個簡單的示例,展示了如何使用inotify API來監控一個文件或目錄的變化。
首先,確保你的系統已經安裝了libinotify-dev開發包,它提供了inotify API的頭文件和靜態庫。你可以使用以下命令來安裝它:
sudo apt-get update
sudo apt-get install libinotify-dev
然后,你可以編寫一個C程序來使用inotify API。下面是一個簡單的示例程序,它會創建一個inotify實例,添加一個監控項,并等待事件發生:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/inotify.h>
#include <unistd.h>
#define EVENT_SIZE ( sizeof (struct inotify_event) )
#define BUF_LEN ( 1024 * ( EVENT_SIZE + 16 ) )
int main(int argc, char **argv)
{
int length, i = 0;
int fd;
int wd;
char buffer[BUF_LEN];
// 檢查命令行參數
if (argc != 2) {
printf("Usage: %s <path-to-watch>\n", argv[0]);
exit(EXIT_FAILURE);
}
// 創建inotify實例
fd = inotify_init();
if (fd < 0) {
perror("inotify_init");
exit(EXIT_FAILURE);
}
// 添加監控項
wd = inotify_add_watch(fd, argv[1], IN_MODIFY | IN_CREATE | IN_DELETE);
if (wd < 0) {
perror("inotify_add_watch");
exit(EXIT_FAILURE);
}
// 等待事件發生
while (1) {
length = read(fd, buffer, BUF_LEN);
if (length < 0) {
perror("read");
exit(EXIT_FAILURE);
}
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);
} else if (event->mask & IN_DELETE) {
printf("File %s was deleted.\n", event->name);
} else if (event->mask & IN_MODIFY) {
printf("File %s was modified.\n", event->name);
}
}
i += EVENT_SIZE + event->len;
}
i = 0;
}
// 移除監控項并關閉inotify實例
(void) inotify_rm_watch(fd, wd);
(void) close(fd);
exit(EXIT_SUCCESS);
}
將上面的代碼保存到一個文件中,例如inotify_example.c,然后使用以下命令編譯它:
gcc inotify_example.c -o inotify_example
運行編譯后的程序,并指定你想要監控的文件或目錄:
./inotify_example /path/to/watch
程序將運行并打印出監控路徑下發生的文件系統事件。
請注意,這個示例程序是一個無限循環,它會一直運行直到被外部信號終止。在實際應用中,你可能需要添加一些邏輯來優雅地處理程序的退出。