Java IO-概述

概述
IONIO
面向流面向缓冲
阻塞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更适合
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Eddy咸鱼

感谢大佬加鸡蛋~

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

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

打赏作者

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

抵扣说明:

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

余额充值