import java.io.*;
import java.nio.file.*;
public class Tmp {
public static void main(String [] args) throws IOException {
int count = 0;
Path path = Paths.get("C:\\tmp\\");
WatchService ws = null;
try {
ws = FileSystems.getDefault().newWatchService();
path.register(ws, StandardWatchEventKinds.ENTRY_CREATE, StandardWatchEventKinds.ENTRY_DELETE,
StandardWatchEventKinds.ENTRY_MODIFY, StandardWatchEventKinds.OVERFLOW);
} catch (IOException ioe) {
ioe.printStackTrace();
}
while(true) {
WatchKey key = null;
try {
key = ws.take();
} catch(InterruptedException ie) {
ie.printStackTrace();
}
for(WatchEvent<?> event: key.pollEvents()) {
switch(event.kind().name()) {
case "OVERFLOW":
System.out.println(++count + ": OVERFLOW");
break;
case "ENTRY_MODIFY":
System.out.println(++count + ": File " + event.context() + " is changed!");
break;
case "ENTRY_CREATE":
System.out.println(++count + ": File " + event.context() + " is created!");
break;
case "ENTRY_DELETE":
System.out.println(++count + ": File " + event.context() + " is deleted!");
break;
default:
System.out.println(++count + ": UNKNOWN EVENT!");
}
}
key.reset();
}
}
}
Когда я запускаю это, а затем открыл Notepad ++, а затем создал новый пустой файл и сохранил его как a.txt
в каталоге C:\tmp\
я получил результат:Почему WatchService генерирует так много операций?
1: File a.txt is created!
2: File a.txt is deleted!
3: File a.txt is created!
Почему? Похоже, что файл был создан, а затем удален, а затем снова создан. Зачем?
Когда я положил текст в файл и сохраняется его выход был:
4: File a.txt is changed!
5: File a.txt is changed!
Почему это изменить дважды?
Я думаю, что поведение, которое вы видите с помощью WatchService, связано с тем, как Notepad ++ и в некоторой степени работает, как работает операционная система Windows при выполнении операций ввода-вывода. Я обнаружил, что что-то вроде «стандартного» блокнота Windows обычно производит наиболее ожидаемое поведение. Я подозреваю, что если вы используете Process Explorer (http://technet.microsoft.com/en-gb/sysinternals/bb896653.aspx) для мониторинга активности ввода-вывода на уровне ОС вы увидите те же результаты. –
Это может быть связано с тем, что записи контента и метаданных выполняются отдельно. – afk5min