中山建站公司,网站建设设计ppt,网站被恶意关键字访问,不参与网站建设的弊端转载自 Java NIO系列教程#xff08;五#xff09; 通道之间的数据传输译文地址 作者#xff1a;Jakob Jenkov 译者#xff1a;郭蕾 校对#xff1a;周泰
在Java NIO中#xff0c;如果两个通道中有一个是FileChannel#xff0c;那你可以直接将数据从一个chan…转载自 Java NIO系列教程五 通道之间的数据传输译文地址 作者Jakob Jenkov 译者郭蕾 校对周泰
在Java NIO中如果两个通道中有一个是FileChannel那你可以直接将数据从一个channel译者注channel中文常译作通道传输到另外一个channel。
transferFrom()
FileChannel的transferFrom()方法可以将数据从源通道传输到FileChannel中译者注这个方法在JDK文档中的解释为将字节从给定的可读取字节通道传输到此通道的文件中。下面是一个简单的例子
01RandomAccessFile fromFile new RandomAccessFile(fromFile.txt, rw);02FileChannel fromChannel fromFile.getChannel();03 04RandomAccessFile toFile new RandomAccessFile(toFile.txt, rw);05FileChannel toChannel toFile.getChannel();06 07long position 0;08long count fromChannel.size();09 10toChannel.transferFrom(position, count, fromChannel);方法的输入参数position表示从position处开始向目标文件写入数据count表示最多传输的字节数。如果源通道的剩余空间小于 count 个字节则所传输的字节数要小于请求的字节数。此外要注意在SoketChannel的实现中SocketChannel只会传输此刻准备好的数据可能不足count字节。因此SocketChannel可能不会将请求的所有数据(count个字节)全部传输到FileChannel中。
transferTo()
transferTo()方法将数据从FileChannel传输到其他的channel中。下面是一个简单的例子
01RandomAccessFile fromFile new RandomAccessFile(fromFile.txt, rw);02FileChannel fromChannel fromFile.getChannel();03 04RandomAccessFile toFile new RandomAccessFile(toFile.txt, rw);05FileChannel toChannel toFile.getChannel();06 07long position 0;08long count fromChannel.size();09 10fromChannel.transferTo(position, count, toChannel);是不是发现这个例子和前面那个例子特别相似除了调用方法的FileChannel对象不一样外其他的都一样。上面所说的关于SocketChannel的问题在transferTo()方法中同样存在。SocketChannel会一直传输数据直到目标buffer被填满。