Java NIO 教程

2018-06-05  本文已影响0人  d3f59bfc7013

Java NIO(Java New IO)是传统IO的一种替代,它是在Java 1.4引进的,它可以代替传统的IO和Java 网络编程的API.Java NIO提供了一种以传统IO不同的工作方式。

Java NIO:Channels and Buffers(通道和缓冲区)
传统的Java IO API主要用来处理字节流和字符流。在NIO中,你主要面向channels和buffers。数据是从channel读入到buffer,或者从buffer写出到channel。
Java NIO:NON-blocking IO(非阻塞式IO)
Java NIO是是非阻塞的IO,例如,一个线程正在从一个channel读入数据到buffer,这个时候channel数据若是还没准备好,那么这个线程可以去处理其他事情。一旦channel准备好了数据,那么线程就可以继续读入数据到buffer。从buffer写出数据到channel也是同理。
Java NIO:Selectors
Java NIO 包含选择器这个概念。选择器能够监控多个channel的事件(例如:连接打开,数据到达等)。因此,一个线程就能过管理多个channel的数据。

IO VS NIO
传统的IO是阻塞式,你调用read()方法,必须等对方给你返回数据你才可以干别的。只要对方不给你返回数据,你的线程就只能在那里干等着。
而NIO就是为了解决这个问题而设计的,它通过设计的Buffers,Channels和Selectors类来解决数据没准备好线程干等的问题。

这里举个医院里边的一个例子来描述一下Java IO和Java NIO。
传统的IO就好像早期医院挂点滴,病人的点滴快完了,护士就得在边上等,等病人的点滴完了后给换新的或者拔针。这个时候一个护士就只能等在这个病人的床边,只能管理到一个病人。

NIO就像改进后的医院,在病人的床边装了告警铃,这个时候病人点滴快挂完了,护士也不用干等着,可以去干其他事情(给其他病人换药水等等......),只有等病人药水挂完了按一下告警铃,护士听到就过来给换一下就好了。这样就一个护士就可以管理很多病人了。

要真正理解NIO就需要带这几个问题思考:

下一节:Java NIO 概述

上一篇下一篇

猜你喜欢

热点阅读