Java NIO系列教程(五) 通道之间的数据传输
2015-12-03 15:56
399 查看
原文地址:http://tutorials.jenkov.com/java-nio/scatter-gather.html
作者:Jakob Jenkov 译者:郭蕾 校对:周泰
在Java NIO中,如果两个通道中有一个是FileChannel,那你可以直接将数据从一个channel(译者注:channel中文常译作通道)传输到另外一个channel。
transferFrom()
FileChannel的transferFrom()方法可以将数据从源通道传输到FileChannel中(译者注:这个方法在JDK文档中的解释为将字节从给定的可读取字节通道传输到此通道的文件中)。下面是一个简单的例子:
方法的输入参数position表示从position处开始向目标文件写入数据,count表示最多传输的字节数。如果源通道的剩余空间小于 count 个字节,则所传输的字节数要小于请求的字节数。
此外要注意,在SoketChannel的实现中,SocketChannel只会传输此刻准备好的数据(可能不足count字节)。因此,SocketChannel可能不会将请求的所有数据(count个字节)全部传输到FileChannel中。
transferTo()
transferTo()方法将数据从FileChannel传输到其他的channel中。下面是一个简单的例子:
是不是发现这个例子和前面那个例子特别相似?除了调用方法的FileChannel对象不一样外,其他的都一样。
上面所说的关于SocketChannel的问题在transferTo()方法中同样存在。SocketChannel会一直传输数据直到目标buffer被填满。
原创文章,转载请注明: 转载自并发编程网 – ifeve.com
本文链接地址: Java NIO系列教程(五) 通道之间的数据传输
作者:Jakob Jenkov 译者:郭蕾 校对:周泰
在Java NIO中,如果两个通道中有一个是FileChannel,那你可以直接将数据从一个channel(译者注:channel中文常译作通道)传输到另外一个channel。
transferFrom()
FileChannel的transferFrom()方法可以将数据从源通道传输到FileChannel中(译者注:这个方法在JDK文档中的解释为将字节从给定的可读取字节通道传输到此通道的文件中)。下面是一个简单的例子:
01 | RandomAccessFile fromFile = new RandomAccessFile( "fromFile.txt" , "rw" ); |
02 | FileChannel fromChannel = fromFile.getChannel(); |
03 |
04 | RandomAccessFile toFile = new RandomAccessFile( "toFile.txt" , "rw" ); |
05 | FileChannel toChannel = toFile.getChannel(); |
06 |
07 | long position = 0 ; |
08 | long count = fromChannel.size(); |
09 |
10 | toChannel.transferFrom(position, count, fromChannel); |
此外要注意,在SoketChannel的实现中,SocketChannel只会传输此刻准备好的数据(可能不足count字节)。因此,SocketChannel可能不会将请求的所有数据(count个字节)全部传输到FileChannel中。
transferTo()
transferTo()方法将数据从FileChannel传输到其他的channel中。下面是一个简单的例子:
01 | RandomAccessFile fromFile = new RandomAccessFile( "fromFile.txt" , "rw" ); |
02 | FileChannel fromChannel = fromFile.getChannel(); |
03 |
04 | RandomAccessFile toFile = new RandomAccessFile( "toFile.txt" , "rw" ); |
05 | FileChannel toChannel = toFile.getChannel(); |
06 |
07 | long position = 0 ; |
08 | long count = fromChannel.size(); |
09 |
10 | fromChannel.transferTo(position, count, toChannel); |
上面所说的关于SocketChannel的问题在transferTo()方法中同样存在。SocketChannel会一直传输数据直到目标buffer被填满。
原创文章,转载请注明: 转载自并发编程网 – ifeve.com
本文链接地址: Java NIO系列教程(五) 通道之间的数据传输
相关文章推荐
- Spring常用注解
- java小项目,坦克大战完整
- java学习笔记-设计模式13(享元模式)
- eclipse安装maven插件及创建webaap 项目发布
- eclipse安装maven插件及创建webaap 项目发布
- C段查询雏形之在Java中反查一个IP上的所有域名(旁站查询) 推荐
- java 向 mysql插入中文字符乱码问题解决
- java多线程学习(一)之创建线程的两种方式
- java线程一
- Spring Security通过URL模式匹配的声明式权限控制
- Java NIO系列教程(四) Scatter/Gather
- springJDBC实现查询方法二
- java学习笔记-设计模式12(组合模式)
- Java 监听机制
- Java NIO系列教程(二) Channel
- java实现lpad函数
- Java学习笔记-接口类学习
- Java NIO系列教程(一) Java NIO 概述
- day_32Java JDBC
- Java Swing paint repaint update 方法的关系