为了账号安全,请及时绑定邮箱和手机立即绑定

Java I/O总结NIO

标签:
Java

I/O的同步异步,阻塞非阻塞:

    阻塞:当执行的操作所需的数据还没准备好时,线程进行等待

    非阻塞:当数据还没准备好时,线程不等待

    同步:执行操作,一直等操作执行完才向下执行

    异步:执行操作,调用接口后不用等待,向下执行

常用的 read() 和 write() 方法都是同步I/O。

传统的I/O是阻塞式的。

问题:当操作所需的数据没有准备好,如数据没有到达,线程会一直等待。

解决:NIO(同步非阻塞I/O)

NIO相当于定义一个调度器selector,把所有实现通信的信道channel注册到selector,由selector调度各个channel的运行情况,实现各个channel不发生阻塞地传输。


Channel信道

FileChannel、DatagramChannel(UDP)、SocketChannel(TCP)、ServerSocketChannel(TCP)

这些通道涵盖了UDP 和 TCP 网络IO,以及文件IO。

Buffer缓冲

    (有三个参数,容量capacity,当前存储位置position,上界limit)

      写模式下,limit等于capacity;读模式下,limit等于position;

ByteBuffer、CharBuffer、DoubleBuffer、FloatBuffer、IntBuffer、LongBuffer、ShortBuffer

这些Buffer覆盖了你能通过IO发送的基本数据类型:byte, short, int, long, float, double 和 char。

Java NIO 还有个 MappedByteBuffer,用于表示内存映射文件。

Selector调度器

    (可以比为一个调度工具)

Selector允许单线程处理多个 Channel,

用于向 buffer 提供数据或者读取 buffer 数据 ,buffer 对象的唯一接口。


过程:

1. 创建selector,channel,把channel信道设为非阻塞模式

2. 绑定socket对象到channel

3. 把channel注册到selector上

4. 调用selector的selectedKeys检查所有信道是否有需要的事情发生,如果有事情发生,返回所有的channel对象。

5. 通过信道,读取通信的数据,读取的是buffer。


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
移动开发工程师
手记
粉丝
64
获赞与收藏
367

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消