IO(NIO)

IO

  • IO操作分为两部分 1)发起数据请求 2)数据读写
  • 阻塞、非阻塞主要是针对线程发起io请求后,是否立即返回来定义的,立即返回称为非阻塞io,否则称为阻塞io。
  • 同步、异步主要针对io数据读写来定义的,读写数据过程中不阻塞线程称为异步io,否则,称为同步io。

区别

1
IO:阻塞(无选择器)
NIO:同步非阻塞 (选择器Selectors)

2
IO是面向流的
NIO是面向缓冲区的

NIO可让您只使用一个(或几个)单线程管理多个通道(网络连接或文件),但付出的代价是解析数据可能会比从一个阻塞流中读取数据更复杂。

场景

如果需要管理同时打开的成千上万个连接,这些连接每次只是发送少量的数据,例如聊天服务器,实现NIO的服务器可能是一个优势。同样,如果你需要维持许多打开的连接到其他计算机上,如P2P网络中,使用一个单独的线程来管理你所有出站连接,可能是一个优势。一个线程多个连接的设计方案如下图所示

image.png

说明

本文只做学习参考,如有任何不准确的地方欢迎指正。

我的邮箱:

你可能感兴趣的:(IO(NIO))