import static java.nio.file.StandardWatchEventKinds.ENTRY_CREATE;
import static java.nio.file.StandardWatchEventKinds.OVERFLOW;
import java.nio.file.FileSystems;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.WatchEvent;
import java.nio.file.WatchKey;
import java.nio.file.WatchService;
/*
* 文件监听
*
* 实现流程如下:
*
*1.为文件系统创建一个WatchService 实例 watcher
*2.为你想监听的目录注册 watcher。注册时,要注明监听那些事件。
*3.在无限循环里面等待事件的触发。当一个事件发生时,key发出信号,并且加入到watcher的queue
* 4.从watcher的queue查找到key,你可以从中获取到文件名等相关信息
* 5.遍历key的各种事件
* 6.重置 key,重新等待事件
* 7.关闭服务
*/
public class TestIOWatchDir {
public void watchDir(String dirPath) {
try {
Path path = Paths.get(dirPath);
WatchService watcher = FileSystems.getDefault().newWatchService();
// path.register(watcher, ENTRY_CREATE, ENTRY_DELETE, ENTRY_MODIFY);
path.register(watcher, ENTRY_CREATE);
while (true) {
WatchKey key = watcher.take();
for (WatchEvent<?> event : key.pollEvents()) {
WatchEvent.Kind<?> kind = event.kind();
if (kind == OVERFLOW) {
continue;
}
Path filePath = (Path) event.context();
System.out.println(filePath);
key.reset();
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
String dirPath = "D:/";
new TestIOWatchDir().watchDir(dirPath);
}
}
备注:参考的相关资源来源于网络ITEYE
分享到:
相关推荐
NULL 博文链接:https://sharong.iteye.com/blog/1569883
java nio 写文件,java nio 写文件
后 基于NIO2.0的网络框架(尚不能使用)。
java nio 读文件,java nio 读文件
Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据...
java nio 写文件样例,java写大数据文件时提高性能
aws-lambda-swift-sprinter:具有swift-nio 2.0支持的AWS Lambda Swift自定义运行时
简单的用Java的NIO读取文件的程序,给大家参考。
适合于文件小但数量比较大的文件传输 传输速度比传统的流IO要快很多,刚接触nio不久,希望有朋友能对它再进行优化,相信很多项目里用的上
本类,是专门为了处理大文件,按行读取开发的类。 采用读文件的缓存 fbb 1024*5 行缓存 bb 256 字节 设计思想: 每次通过nio读取字节到 fbb中 然后对fbb自己中的内容进行行判断即 10 回车 13 行号 0 文件...
NIO 处理大文件
1.4 JDK7新特性<四> NIO2.0 文件系统 . . . 1.5 JDK7新特性<五> fork/join 框架 . . . . . 1.6 JDK7新特性<六> 监听文件系统的更改 1.7 JDK7新特性<七> 遍历文件树 . . . . . . . 1.8 JDK7新特性<八>异步io/AIO ...
利用NIO中的类进行开发的文件复制实例,学习下类的使用
本类,是专门为了处理大文件,按行读取开发的类。 采用读文件的缓存 fbb 1024*5 行缓存 bb 256 字节 设计思想: 每次通过nio读取字节到 fbb中 然后对fbb自己中的内容进行行判断即 10 回车 13 行号 0 文件结束 ...
JAVA NIO 简单PFT 文件服务 上传 下载 列表
使用nio byteBuffer 实现按行读取文件(大文件) 在window/linux/macOS上均测试通过 对于中文乱码也已处理成功 完整注释,可随需求更改 有问题请邮件:mly610865580@126.com
java NIO文件操作(中文版pdf),希望对大家有帮助,(转载)
ParallelGit 是为 Git 应用准备的高性能 Java NIO 内存文件系统。ParallelGit 是基于 JGit 构建的, 可以帮助 Java 项目快速的访问 Git 文件。ParallelGit 可以帮助你操作本地 Git仓库,允许你通过 Java 7 nio 文件...
Java NIO 源码适合初学者,里面包括通道和Buffer的基本适用,以及文件锁,和内存文件映射等等
这是用java做的文件分割器,有两个版本,一个使用IO,另一个使用NIO,可以分割任意格式的文件。是在Linux下的eclipse中做的。