NIO
Wang-Junchao
这个作者很懒,什么都没留下…
展开
-
Java NIO 02=====Channel
Java NIO的通道类似流,但又有些不同:既可以从通道中读取数据,又可以写数据到通道。但流的读写通常是单向的。通道可以异步地读写。通道中的数据总是要先读到一个Buffer,或者总是要从一个Buffer中写入。正如上面所说,从通道读取数据到缓冲区,从缓冲区写入数据到通道。原创 2015-05-31 19:07:34 · 1051 阅读 · 0 评论 -
Java NIO 09=====ServerSocketChannel
Java NIO中的 ServerSocketChannel 是一个可以监听新进来的TCP连接的通道, 就像标准IO中的ServerSocket一样。ServerSocketChannel类在 java.nio.channels包中。原创 2015-06-01 07:57:45 · 1070 阅读 · 0 评论 -
Java NIO 11=====DatagramChannel
Java NIO中的DatagramChannel是一个能收发UDP包的通道。因为UDP是无连接的网络协议,所以不能像其它通道那样读取和写入。它发送和接收的是数据包。原创 2015-06-01 08:09:08 · 856 阅读 · 0 评论 -
Java NIO 11=====Pipe
Java NIO 管道是2个线程之间的单向数据连接。Pipe有一个source通道和一个sink通道。数据会被写到sink通道,从source通道读取。原创 2015-06-01 08:16:08 · 736 阅读 · 0 评论 -
Java NIO 03=====Buffer
Java NIO中的Buffer用于和NIO通道进行交互。如你所知,数据是从通道读入缓冲区,从缓冲区写入到通道中的。缓冲区本质上是一块可以写入数据,然后可以从中读取数据的内存。这块内存被包装成NIO Buffer对象,并提供了一组方法,用来方便的访问该块内存。原创 2015-05-31 19:32:45 · 1053 阅读 · 0 评论 -
Java NIO 08=====SocketChannel
Java NIO中的SocketChannel是一个连接到TCP网络套接字的通道。可以通过以下2种方式创建SocketChannel:打开一个SocketChannel并连接到互联网上的某台服务器。一个新连接到达ServerSocketChannel时,会创建一个SocketChannel。原创 2015-06-01 07:51:06 · 1031 阅读 · 0 评论 -
Java NIO 07=====FileChannel
Java NIO中的FileChannel是一个连接到文件的通道。可以通过文件通道读写文件。FileChannel无法设置为非阻塞模式,它总是运行在阻塞模式下原创 2015-06-01 07:42:06 · 865 阅读 · 0 评论 -
Java NIO 06=====Selector
Selector(选择器)是Java NIO中能够检测一到多个NIO通道,并能够知晓通道是否为诸如读写事件做好准备的组件。这样,一个单独的线程可以管理多个channel,从而管理多个网络连接。下面是本文所涉及到的主题列表:为什么使用Selector?Selector的创建向Selector注册通道SelectionKey通过Selector选择通道wakeUp()close()完整原创 2015-06-01 08:33:49 · 822 阅读 · 0 评论 -
Java NIO 04=====Scatter/Gather
Java NIO开始支持scatter/gather,scatter/gather用于描述从Channel(译者注:Channel在中文经常翻译为通道)中读取或者写入到Channel的操作。分散(scatter)从Channel中读取是指在读操作时将读取的数据写入多个buffer中。因此,Channel将从Channel中读取的数据“分散(scatter)”到多个Buffer中。聚集(gather)写入Channel是指在写操作时将多个buffer的数据写入同一个Channel,因此,Channel 将原创 2015-05-31 19:34:45 · 840 阅读 · 0 评论 -
Java NIO 05=====通道之间的数据传输
在Java NIO中,如果两个通道中有一个是FileChannel,那你可以直接将数据从一个channel(译者注:channel中文常译作通道)传输到另外一个channel。原创 2015-05-31 19:40:17 · 1038 阅读 · 0 评论 -
Java NIO 00=====开篇
Java NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java NIO提供了与标准IO不同的IO工作方式。原创 2015-05-31 18:53:45 · 1211 阅读 · 0 评论 -
Java NIO 01=====概述
Java NIO 由以下几个核心部分组成:ChannelsBuffersSelectors虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Channel,Buffer 和 Selector 构成了核心的API。其它组件,如Pipe和FileLock,只不过是与三个核心组件共同使用的工具类。因此,在概述中我将集中在这三个组件上。其它组件会在单独的章节中讲到。原创 2015-05-31 18:58:34 · 934 阅读 · 0 评论 -
Java NIO 12=====Java NIO与IO
Java NIO和IO的主要区别原创 2015-06-01 08:24:10 · 959 阅读 · 0 评论