问:你知道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直观易用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FIN技术铺

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值