阅读WatchEvent的
javadocs,我看到
count()方法让我知道一个事件是否被其结果重复.
Returns the event count. If the event count is greater than 1 then this is a repeated event.
这究竟是什么意思?是否意味着两个或多个WatchEvent对象引用相同的“事件”(例如正在创建的文件)?
我正在试验Oracle网站上的example用于新的WatchService API,这部分让我很困惑,特别是因为我将为相同测试代码的连续运行获得不同数量的事件(我使用FileWriter写入文件手动与它交互),但count()的结果永远不会超过1.
最佳答案 我花了一些时间试验这个,这是我的结论:
An event is repeated, for file f and event type e, if multiple e type events occurred to the same file f.
If an e type event occurred to multiple files f1, f2, and f3, but only once each, then none of those events are repeated.
当你从WatchService中获取()一个WatchKey时,你会得到一个WatchEvent,它针对每个经历过事件的文件,对于它所经历的每种事件类型.如果自上次从WatchService获取WatchKey以来,该类型的事件多次发生在该文件中,则.count()将大于1.
也就是说,如果您正在观看其中包含A.txt的目录,则会发生以下事件:
> B.txt在目录中创建.
> B.txt被写入.
> A.txt被写入.
> B.txt已删除.
> A.txt再次写入.
您将获得四个WatchEvent:
> B.txt的创建事件.
> B.txt的修改事件.
> A.txt的修改事件.它的.count()将为2.
> B.txt的删除事件.
这意味着您永远不会在WatchKey中获得超过3 * n个事件,其中n是任何点上目录中的文件数.
在StandardWatchEventKinds中定义了四种类型的事件,但OVERFLOW事件表示事件可能已丢失,因此我从上面的数字中省略了它.