JavaNIO之Channel】的更多相关文章

Channel的本质是通道,用来连接JVM之外数据向JVM内传输数据,比如来自于硬盘的文件,来自于网络的数据包.JVM之外的数据就是通过Channel进行数据传输:如果把Channel比作河道,那么作为数据的载体就是ByteBuffer,buffer的隐喻就是容器,专门用于传输数据的容器: 作为channel的获取,是通过文件对象RandomAccessFile.getChannel()方式获得:然后通过read()以及write()方法来通过Buffer写入以及读取. Buffer的flip方…
1:Channel是什么 通道表示与实体的开放连接,例如硬件设备.文件.网络套接字或能够执行一个或多个不同 I/O 操作(例如读取或写入)的程序组件. 1.1:Channel与Stream的对比 Stream Channel 为什么 是否支持异步 否 是 是否同时支持输入和输出 否 是 Stream的输入.输出分别需要InputStream.OutputStream 是否必须结合Buffer使用 否 是 缓冲区是通道内部发送数据和接收数据的端点 性能 低 高 通道是访问IO服务的导管,通过通道,…
Channel聚集(gather)写入: 聚集写入( Gathering Writes)是指将多个 Buffer 中的数据“聚集”到 Channel. 特别注意:按照缓冲区的顺序,写入 position 和 limit 之间的数据到 Channel . Channel分散(scatter)读取: 分散读取( Scattering Reads)是指从 Channel 中读取的数据“分散” 到多个 Buffer 中. 特别注意:按照缓冲区的顺序,从 Channel 中读取的数据依次将 Buffer…
通道(Channel)的数据传输(采用非直接缓冲区) @Test public void testChannel() throws IOException { FileInputStream fileInputStream = new FileInputStream("Java NIO.pdf"); FileOutputStream fileOutputStream = new FileOutputStream("2.pdf"); // 1.获取通道 FileCha…
通道(Channel): 由java.nio.channels包定义的,Channel表示IO源与目标打开的连接,Channel类似于传统的“流”,只不过Channel本身不能直接访问数据,Channel只能与Buffer进行交互.通道主要用于传输数据,从缓冲区的一侧传到另一侧的实体(如文件.套接字...),反之亦然:通道是访问IO服务的导管,通过通道,我们可以以最小的开销来访问操作系统的I/O服务:顺便说下,缓冲区是通道内部发送数据和接收数据的端点. 在标准的IO当中,都是基于字节流/字符流进…
NIO:一种同步非阻塞的 I/O 模型,也是 I/O 多路复用的基础. 同步与异步 同步:发起一个调用后,被调用者未处理完请求之前,调用不返回. 异步:发起一个调用后,立刻得到被调用者的回应表示已接收到请求,但是被调用者并没有返回结果,此时我们可以处理其他的请求,被调用者通常依靠事件,回调等机制来通知调用者其返回结果. 同步和异步的区别最大在于异步的话调用者不需要等待处理结果,被调用者会通过回调等机制来通知调用者其返回结果. 阻塞和非阻塞 阻塞:发起一个请求,调用者一直等待请求结果返回,也就是当…
原文地址:http://tutorials.jenkov.com/java-nio/channels.html JAVA NIO channels和流的概念很像,下面是他们的一些区别: 你可以对channel进行读写,流只能一种操作(读或写). channel可以异步的读写. channel总是读入.写出到buffer. 根据上面提到的,你可以从channel中读取数据到buffer中,也可以从buffer中写入数据到channel中.下即可解释: JAVA NIO: channels读入数据到…
(一) Java NIO 概述 Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Channel,Buffer 和 Selector 构成了核心的API.其它组件,如Pipe和FileLock,只不过是与三个核心组件共同使用的工具类.因此,在概述中我将集中在这三个组件上.其它组 件会在单独的章节中讲到. Channel 和 Buffer 基本上,所有的 IO 在NIO 中都从一个Chan…
package com.nio.test; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.RandomAccessFile; import java.nio.ByteBuffer; import java.nio.MappedByteBuffer; im…
原文链接:http://tutorials.jenkov.com/java-nio/channel-to-channel-transfers.html 在Java NIO中如果一个channel是FileChannel类型的,那么他可以直接把数据传输到另一个channel.这个特性得益于FileChannel包含的transferTo和transferFrom两个方法. transferFrom() FileChannel.transferFrom方法把数据从通道源传输到FileChannel:…