在以前的版本中,如果程序需要监控文件的变化,则可以考虑启动—条后台线程,这条后台线程每隔一段时间去“遍历”一次指定目录的文件,如果发现此次遍历结果与上次遍历结果不同,则认为文件发生了变化.但这种方式不仅十分烦琐,而且性能也不好。

NIO.2的Path类提供了如下一个方法来监听文件系统的变化。

JAVA的table能触发监听吗 java监听表变化_指定目录

register( WatchService watcher, WatchEvent.Kind>… events):用watcher监听该path代表的目录下的文件变化。events 参数指定要监听哪些类型的事件。在这个方法中WatchService代表-一个文件系统监听服务,它负责监听path代表的目录下的文件变化。一旦 使用register()方法完成注册之后,接下来就可调用WatchService 的如下三个方法来获取被监听目录的文件变化事件。

JAVA的table能触发监听吗 java监听表变化_指定目录

WatchKey poll():获取下-个WatchKey,如果没有WatchKey发生就立即返回null。

JAVA的table能触发监听吗 java监听表变化_指定目录

WatchKey poll(long timeout, TimeUnit unit):尝试等待timeout 时间去获取下-个WatchKey.

JAVA的table能触发监听吗 java监听表变化_指定目录

WatchKey take():获取下一个WatchKey,如果没有WatchKey发生就一直等待 。

如果程序需要一直 监控,则应该选择使用take()方法;如果程序只需要监控指定时间,则可考虑使用poll()方法。下面程序示范了使用WatchService 来监控C:盘根路径下文件的变化。

importjava.nio.file.*;
publicclassTest{
publicstaticvoidmain(String[]args)throwsException{
//获取文件系统的Wwatchservice对象
WatchServicewatchService=FileSystems.getDefault().newWatchService();
//为C:盘根路径注册监听
Paths.get("C:/").register(watchService
,StandardWatchEventKinds.ENTRY_CREATE
,StandardWatchEventKinds.ENTRY_MODIFY
,StandardWatchEventKinds.ENTRY_DELETE);
while(true){
//获取下一个文件变化事件
WatchKeykey=watchService.take();// ①
for(WatchEvent>event:key.pollEvents()){
System.out.println(event.context()+" 文件发生了"
+event.kind()+"事件! ");
//重设WatchKey
booleanvalid=key.reset();
//如果重设失败,退出监听
if(!valid){
break;
}
}
}
}
}

上面程序使用了一个死循环重复获取C:盘根路径下文件的变化,程序在①号代码处试图获取下一个WatchKey,如果没有发生就等待。因此C:盘根路径下新建文本文档tnt文件发生了ENTEY_CREATE事杆:新建文本文档tst文件发生了BNTST_PULTE事件:

每次文件的变化都会被该程序监听到。运行该程序,然后在C:盘下新建一个文件,再删除该文件。通过使用WatchService 可以非常优雅地监控指定目录下文件的变化,至于文件发生变化后,程序应该进行哪些处理,这就取决于程序的业务需要了。