Java NIO 系列学习(一)Java NIO概述

参考资料:html

  http://www.importnew.com/19816.html缓存

  http://ifeve.com/overview/服务器

NIO 三大核心部分:网络

  Channel(通道)、Buffer(缓冲区)、Selector(选择区)app

NIO和传统IO的不一样之处:spa

  传统IO  : 线程

    基于字节流和字符流进行操做;htm

    IO是面向流的:blog

      意味着每次从流中读取一个或多个字节,直至读取全部字节,它们没有被缓存在任何地方。此外,它不能先后移动流中的数据,若是须要先后移动从流中读取的数据,须要先将它缓存到一个缓冲区;教程

    IO的各类流是阻塞的:

      意味着当一个线程调用read()或write()时,该线程被阻塞,直到有一些数据被读取,或数据彻底写入,在此期间该线程不能再干任何事情了。

  NIO       :

    基于Channel和Buffer进行操做:数据老是从通道读取到缓冲区中,或者从缓冲区写入到通道中。Selector用于监听多个通道的事件。所以,单个线程能够监听多个数据通道;

    NIO是面向缓冲区的:

      NIO的缓冲导向方法略有不一样:数据读取到一个它稍后处理的缓冲区,须要时可在缓冲区中先后移动,增长了处理过程当中的灵活性。可是,还须要检查是否该缓冲区中包含全部您须要处理的数据。并且,须要确保当更多的数据读入缓冲区时,不要覆盖缓冲区里还没有处理的数据;

    NIO的非阻塞模式:

      使一个线程从某通道发送请求读取数据,可是它仅能获得目前可用的数据,若是目前没有数据可用时,就什么都不会获取,而不是保持线程阻塞,因此直至数据变的能够读取以前,该线程能够继续作其余的事情。

      非阻塞写也是如此,一个线程请求写入一些数据到某通道,但不须要等待它彻底写入,这个线程同时能够去作别的事情。

      线程一般将非阻塞IO的空闲时间用于在其余通道上执行IO操做,因此一个单独的线程如今能够管理多个输入和输出通道。

Channel:

  Channel和IO中Stream(流)是差很少一个等级的。只不过Stream是单向的,譬如:InputStream,OutputStream. 而Channel是双向的,既能够用来进行读操做,又能够用来进行写操做。

  NIO中Channel的主要实现有:

    FileChannel、DatagramChannel、SocketChannel、ServerSocketChannel

    FileChannel从文件中读写数据(文件IO);

    DatagramChannel能经过UDP读写网络中的数据;

    SocketChannel能经过TCP读写网络中的数据;

    ServerSocketChannel能够监听新进来的TCP链接,像Web服务器那样。对每个新进来的链接都会建立一个SocketChannel。

Buffer:

  NIO中关键的Buffer实现:

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

    分别对应基本数据类型:byte、char、double、float、int、long、short。

    NIO中还有MappedByteBuffer,用于标识内存映射文件。

Selector:

  Selector运行单线程处理多个Channel。若是你的应用打开了多个通道,但每一个链接的流量都很低,使用Selector就会很方便。例如,在一个聊天服务器中。

  这是在一个单线程中使用一个Selector处理3个Channel的图示:

     

  要使用Selector,得向Selector注册Channel,而后调用它的select()方法。这个方法会一直阻塞到某个注册的通道有事件就绪。一旦这个方法返回,线程就能够处理这些事件,事件的例子有如新链接进来,数据接收等。

相关文章
相关标签/搜索