JAVA的NIO模型

什么是NIO

java的NIO全称为non-blocking IO,使用它可以提供非阻塞式的高伸缩性网络

NIO的基本组成

NIO主要有三部分:Channel、Buffer和Selector
Channel是一个对象,可以用过它进行数据的读取和写入,它是面向缓冲区的,所有的数据都通过Buffer来处理,永远不会直接将字节写入通道中,而是将数据写入包含一个字节或者多个字节的缓冲区

早多线程模式下,阻塞IO时,一个线程只能处理一个请求,比如Http请求,当请求响应式关闭连接,释放线程资源。Selector选择器的作用就是配合一个线程来管理多个Channel,获取这些Channel上发生的事件,这些Channel工作在非阻塞模式下,不会让线程一直在一个Channel上,适合连接数特别多,但流量低的场景

调用Selector的select()方法会阻塞直到Channel发送了读写就绪事件,这些事件发生,select()方法就会返回这些事件交给thread来处理。

在这里插入图片描述

NIO的epoll BUG

好的,下面是使用Java NIO模型中的FileChannel实现文件复制的代码实现: ```java import java.io.FileInputStream; import java.io.FileOutputStream; import java.nio.ByteBuffer; import java.nio.channels.FileChannel; public class FileCopyDemo { public static void main(String[] args) throws Exception { FileInputStream inputStream = new FileInputStream("source.txt"); FileChannel inputChannel = inputStream.getChannel(); FileOutputStream outputStream = new FileOutputStream("target.txt"); FileChannel outputChannel = outputStream.getChannel(); ByteBuffer buffer = ByteBuffer.allocate(1024); while (inputChannel.read(buffer) != -1) { buffer.flip(); outputChannel.write(buffer); buffer.clear(); } inputChannel.close(); outputChannel.close(); inputStream.close(); outputStream.close(); System.out.println("File copied successfully!"); } } ``` 以上代码中,我们首先定义了一个FileInputStream对象,并通过调用getChannel()方法创建一个FileChannel对象来进行文件读取。接着我们定义了一个FileOutputStream对象,并通过调用getChannel()方法创建一个FileChannel对象来进行文件写入。 然后我们使用allocate()方法创建一个1024字节大小的ByteBuffer对象。在while循环中,我们不断从inputChannel中读取数据到buffer中,然后将buffer的position设置为0,limit设置为buffer的当前position,接着通过write()方法将buffer中的数据写入到outputChannel中。 最后,我们需要关闭输入输出流和FileChannel对象,并输出文件复制成功的提示信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值