gpt4 book ai didi

java - WatchService:错过和未处理的事件

转载 作者:搜寻专家 更新时间:2023-10-31 20:19:15 24 4
gpt4 key购买 nike

我在使用 WatchService 时遇到问题。这是我的代码片段:

public void watch(){
//define a folder root
Path myDir = Paths.get(rootDir+"InputFiles/"+dirName+"/request");

try {
WatchService watcher = myDir.getFileSystem().newWatchService();
myDir.register(watcher, StandardWatchEventKinds.ENTRY_CREATE);

WatchKey watckKey = watcher.take();

List<WatchEvent<?>> events = watckKey.pollEvents();
for (WatchEvent event : events) {
//stuff
}
}catch(Exception e){}

watckKey.reset();

}

*首先,要知道 watch() 是在无限循环中调用的。

问题是当一次创建多个文件时,一些事件丢失了。例如,如果我将三个文件复制粘贴到“.../request”文件夹中,只有一个被捕获,其他的仍然没有发生,也没有触发 OVERFLOW 事件。在一些不同的计算机和操作系统中,它最多可以达到两个文件,但如果一个尝试了 3 个或更多,其余的仍然没有动过。

虽然我找到了解决方法,但我认为这不是最佳做法。这是流程:

进程开始然后停止在

WatchKey watckKey = watcher.take();

如预期,(根据 Processing events )。然后,我将 3 个文件放在“request”文件夹中,因此,进程在

List<WatchEvent<?>> events = watckKey.pollEvents();

问题就在这里。似乎线程通过这条线的速度太快了,以至于两个 CREATED 事件留在后面并丢失了,只有一个被采用。解决方法是在这一行的正上方添加一行,如下所示:

Thread.sleep(1000);
List<WatchEvent<?>> events = watckKey.pollEvents();

这似乎是一个解决方案,至少对于三个或更多的同步文件来说是这样,但它根本不可扩展。所以总而言之,我想知道这个问题是否有更好的解决方案。仅供引用,我运行的是 Win 7 64

提前致谢!

最佳答案

请务必重置您的 watchKey。上述某些答案没有,这也可以解释丢失的事件。我推荐Oracle官方文档中给出的示例:https://docs.oracle.com/javase/tutorial/essential/io/notification.html

请注意,即使使用正确,文件服务的可靠性在很大程度上也取决于底层操作系统。通常,应将其视为不提供 100% 保证的尽力而为机制。

关于java - WatchService:错过和未处理的事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29802876/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com