欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 家装 > 问:你知道IO和NIO有哪些区别不?

问:你知道IO和NIO有哪些区别不?

2024/10/25 2:23:41 来源:https://blog.csdn.net/li_guolin/article/details/141948639  浏览:    关键词:问:你知道IO和NIO有哪些区别不?
一、先表示一下_
Java IOJava NIO
主要特点面向流(Stream)的I/O操作面向缓冲区(Buffer)和通道(Channel)的I/O操作,支持非阻塞I/O和选择器(Selector)
常用方法InputStreamOutputStreamReaderWriterChannel(如FileChannelSocketChannel)、Buffer(如ByteBuffer)、Selector
阻塞模式阻塞模式,调用read/write方法时线程会阻塞非阻塞模式,线程在等待数据期间可以继续执行其他任务
选择器(Selector)不支持支持,可以监视多个通道的状态,提高I/O操作的效率
缓冲区(Buffer)缓冲区使用较少,数据直接通过流进行读写使用缓冲区进行数据的读写,提高了数据处理的灵活性
适用场景小文件读写、简单的网络通信等大文件处理、高并发网络编程、需要高效I/O操作的场景
二、代码示例

Java IO示例(文件读取):

try (FileInputStream fis = new FileInputStream("file.txt");BufferedInputStream bis = new BufferedInputStream(fis);InputStreamReader isr = new InputStreamReader(bis, StandardCharsets.UTF_8);BufferedReader br = new BufferedReader(isr)) {String line;while ((line = br.readLine()) != null) {System.out.println(line);}
} catch (IOException e) {e.printStackTrace();
}

Java NIO示例(文件读取,使用缓冲区):

try (FileChannel fileChannel = FileChannel.open(Paths.get("file.txt"), StandardOpenOption.READ);ByteBuffer buffer = ByteBuffer.allocate(1024)) {while (fileChannel.read(buffer) != -1) {buffer.flip(); // 切换为读模式while (buffer.hasRemaining()) {System.out.print((char) buffer.get());}buffer.clear(); // 准备下一次读取}
} catch (IOException e) {e.printStackTrace();
}
三、仔细聊聊
  1. 主要特点

    • Java IO:基于流的I/O操作,数据直接从流中读取或写入,不支持非阻塞I/O。
    • Java NIO:基于缓冲区和通道的I/O操作,数据先读入缓冲区,再从缓冲区处理,支持非阻塞I/O和选择器机制,适合处理大量数据和高并发场景。
  2. 常用方法

    • Java IO:使用InputStreamOutputStreamReaderWriter等类进行数据的读写。
    • Java NIO:使用Channel(如FileChannelSocketChannel)进行数据的传输,Buffer(如ByteBuffer)作为数据容器,Selector用于监视多个通道的状态。
  3. 阻塞模式

    • Java IO:在调用read/write方法时,如果数据不可用或缓冲区已满,线程会阻塞,直到操作完成。
    • Java NIO:提供了非阻塞模式,线程在等待数据期间可以继续执行其他任务,提高了程序的并发性能。
  4. 选择器(Selector)

    • Java IO:不支持选择器机制,每个I/O操作都需要一个线程来处理。
    • Java NIO:引入了选择器机制,可以监视多个通道的状态,当某个通道有数据可读或可写时,选择器会通知相应的线程进行处理,大大提高了I/O操作的效率。
  5. 缓冲区(Buffer)

    • Java IO:虽然也使用缓冲区(如BufferedInputStreamBufferedOutputStream),但这些缓冲区主要是为了减少系统调用次数和提高读写效率,并不是NIO中的核心概念。
    • Java NIO:缓冲区是核心概念之一,数据在通道和应用程序之间通过缓冲区进行传输,提供了更灵活的数据处理方式。
  6. 适用场景

    • Java IO:适用于小文件读写、简单的网络通信等场景。
    • Java NIO:适用于大文件处理、高并发网络编程、需要高效I/O操作的场景。
四、结尾

Java IO

  • 优点:简单易用,API直观。
  • 缺点:阻塞模式导致性能瓶颈,不适合处理大量并发请求。

Java NIO

  • 优点:支持非阻塞I/O和选择器机制,提高了程序的并发性能和I/O操作效率;缓冲区机制提供了更灵活的数据处理方式。
  • 缺点:编程模型相对复杂,在某些简单场景下可能不如Java IO直观易用。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com