Java NIO2 异步IO支持

NIO2

从 Java 7 在之前的NIO基础上,它提供了异步 IO 操作、文件系统访问增强等诸多功能

路径(Path)接口

Path 接口代表了文件系统的路径。它可以用来定位一个文件或目录。

提供了多种方法来解析、转换和查询路径信息。Paths 类提供了一些静态方法用于获取 Path 。

java 复制代码
 Path path1 = Paths.get("/home/user/documents");
 Path path2 = Paths.get("file.txt");

Files

Files 类提供了大量的静态方法来执行文件操作,比如 读取、写入、复制、删除、移动

java 复制代码
 Path sourcePath = Paths.get("source.txt");
 Path targetPath = Paths.get("target.txt");
             
Files.copy(sourcePath, targetPath);

异步 IO

相对而言这是最重要的功能,异步 IO 操作使得在处理大量 IO 任务时可以充分利用系统资源,NIO2 主要增加了 文件 和 Socket异步IO支持。

  • AsynchronousFileChannel

允许异步地从文件读取数据或向文件写入数据。

适用于需要高并发性能且不希望线程被I/O操作阻塞的情况。

  • AsynchronousSocketChannel 和 AsynchronousServerSocketChannel:

分别对应客户端和服务端的异步套接字通信,支持非阻塞模式下的连接建立、数据发送与接收。

Future 和 CompletionHandler

异步IO 主要通过 CompletionHandler 接口或 Future 对象来处理完成事件。

java 复制代码
Path path = Paths.get("data.txt");
AsynchronousFileChannel fileChannel = 
    AsynchronousFileChannel.open(path, StandardOpenOption.WRITE);

ByteBuffer buffer = ByteBuffer.allocate(1024);
long position = 0;
buffer.put("test future".getBytes());
buffer.flip();

Future<Integer> operation = fileChannel.write(buffer, position);
...
java 复制代码
Path path = Paths.get("data.txt");
hronousFileChannel fileChannel = 
    AsynchronousFileChannel.open(path, StandardOpenOption.WRITE);

ByteBuffer buffer = ByteBuffer.allocate(1024);
long position = 0;

buffer.put("test CimpletionHandler".getBytes());
buffer.flip();

fileChannel.write(buffer, position, buffer, new CompletionHandler<Integer, ByteBuffer>() {

    @Override
    public void completed(Integer result, ByteBuffer attachment) {
        System.out.println("bytes written: " + result);
    }

    @Override
    public void failed(Throwable exc, ByteBuffer attachment) {
        exc.printStackTrace();
    }
});
相关推荐
武子康1 小时前
Java-71 深入浅出 RPC Dubbo 上手 父工程配置编写 附详细POM与代码
java·分布式·程序人生·spring·微服务·rpc·dubbo
武子康3 小时前
Java-72 深入浅出 RPC Dubbo 上手 生产者模块详解
java·spring boot·分布式·后端·rpc·dubbo·nio
_殊途3 小时前
《Java HashMap底层原理全解析(源码+性能+面试)》
java·数据结构·算法
椰椰椰耶4 小时前
【Spring】拦截器详解
java·后端·spring
没有bug.的程序员5 小时前
JAVA面试宝典 - 《MyBatis 进阶:插件开发与二级缓存》
java·面试·mybatis
没有羊的王K7 小时前
SSM框架学习——day1
java·学习
又菜又爱coding7 小时前
安装Keycloak并启动服务(macOS)
java·keycloak
不知道叫什么呀7 小时前
【C】vector和array的区别
java·c语言·开发语言·aigc
wan_da_ren8 小时前
JVM监控及诊断工具-GUI篇
java·开发语言·jvm·后端
cui_hao_nan8 小时前
JAVA并发——什么是Java的原子性、可见性和有序性
java·开发语言