美文网首页
java IO-1-IO和NIO

java IO-1-IO和NIO

作者: 宠辱不惊的咸鱼 | 来源:发表于2019-09-30 09:19 被阅读0次

    概述

    IO NIO
    面向流 面向缓冲
    阻塞IO 非阻塞IO
    选择器
    • 面向流
      • 无法移动数据指针,只能从头读到尾
    • 面向缓冲
      • 可以在Buffer中移动数据指针
    • 阻塞IO
      • read和write期间线程不能做其他事情
    • 非阻塞IO
      • channel的read和write期间,线程可以管理别的channel,做其他事情
    • 选择器(Selectors)
      • 允许一个线程监视多个通道,注册多个通道于一个选择器,线程“选择”通道
      • 选择器选择就绪通道进行操作

    应用程序设计时所表现的差异

    • API不同
    • 数据处理
      • IO
        • 从InputStream或Reader逐字节(符)读取数据
        • 处理状态由程序执行时间决定:一旦reader.readLine()返回,就知道文本行肯定已读完
        • 可以明确知道每步拿到的数据是什么
    // 行文本
    Name: Anna
    Age: 25
    Email: anna@mailserver.com
    Phone: 1234567890
    // 处理方式
    InputStream input = socket.getInputStream();
    BufferedReader reader = new BufferedReader(new InputStreamReader(input));
    String nameLine   = reader.readLine();
    String ageLine    = reader.readLine();
    String emailLine  = reader.readLine();
    String phoneLine  = reader.readLine();
    
      • NIO
        • 从通道读取字节到ByteBuffer
        • 方法返回时:并不知道所需数据是否全部已在缓冲区;所知道的是:缓冲区包含一些字节
        • 对缓冲区中数据是否已完整可用的判断比较困难
    ByteBuffer buffer = ByteBuffer.allocate(48);
    int bytesRead = inChannel.read(buffer);
    while(!bufferFull(bytesRead)) {
        bytesRead = inChannel.read(buffer);
    }
    
    • 线程数量
      • IO
        • 需多线程
      • NIO
        • 一个线程管理多个channel
        • 大量短连接:NIO更适合;少量高带宽连接:IO更适合

    相关文章

      网友评论

          本文标题:java IO-1-IO和NIO

          本文链接:https://www.haomeiwen.com/subject/yudcpctx.html