0

我使用 FileObserver 监控“/proc/net/arp”目录,但在 onEvent 方法中无法获取任何事件。代码如下:

public class MyFileObserver extends FileObserver{

private Set<OnClientConnectListener> mListeners;
private boolean mWatching = false;

public MyFileObserver(String path) {
    super(path);
}

@Override
public void onEvent(int event, String path) {
    Log.d("conio","event:"+event+" , path:"+path);
    switch(event) {
    case FileObserver.MODIFY:
        Log.d("conio","event modify");
        ArrayList<String> ips = WifiHelper.getClientList(true, 3000);

        if(mListeners != null) {
            for(OnClientConnectListener lis : mListeners) {
                lis.onConnectChange(ips);
            }
        }
        break;
    }
}

我如何监控'/proc/net/arp',我检查它是否已读取此文件的权限,我可以使用 FileInputStream 从中读取数据。

4

1 回答 1

1

文件观察器基于 inotify 机制,但是 /proc 不是通用文件系统。所有的“文件”只是内核的一个接口,您可以通过它从/向内核获取/设置信息。所有内容都是即时生成的。这就是 inotify 在 /proc 系统上不起作用的原因。请参考此

但是,Ubuntu 13.04 的用户表示这可以正常工作。也许最新的内核支持这种设施。我在这里复制了帖子,原始页面在这里

编译以下程序(inotifyerr.c)

#include <stdlib.h>
#include <stdio.h>
#include <sys/inotify.h>

int main(int argc, char* argv[]){
    int fd = inotify_init();
    if (fd == -1){
        perror("inotify_init");
    }
    char path[256];
    sprintf(path,"/proc/%s",argv[1]);
    printf("watching %s\n",path);
    int wd = inotify_add_watch(fd,path,IN_ALL_EVENTS);
    if (wd == -1){
        perror("inotify_add_watch");
    }
    char buf[1024];
    ssize_t siz = read(fd,buf,1024);
    if (siz == -1){
        perror("inotify read");
    }
    printf("read done, bytes: %d\n",siz);
}

gcc inotifyerr.c

在 Ubuntu 13.04 上进行了测试,它工作正常:

sworddragon@ubuntu:~/data$ sleep 20 &
[1] 3009
sworddragon@ubuntu:~/data$ ls /proc/3009
attr cgroup comm cwd fd latency map_files mountinfo net oom_adj pagemap sched smaps statm task
autogroup clear_refs coredump_filter environ fdinfo limits maps mounts ns oom_score personality schedstat stack status wchan
auxv cmdline cpuset exe io loginuid mem mountstats numa_maps oom_score_adj root sessionid stat syscall
sworddragon@ubuntu:~/data$ ./a.out 3009
watching /proc/3009
read done, bytes: 128

在 /proc 上使用 inotifywait 也可以正常工作

于 2013-12-04T02:44:20.293 回答