美文网首页爱编程,爱生活
Java NIO 通道之间的数据传输

Java NIO 通道之间的数据传输

作者: 熬夜的猫头鹰 | 来源:发表于2018-06-16 23:35 被阅读0次

Java NIO 通道之间的数据传输

在Java NIO中,如果两个通道中有一个是FileChannel,那你可以直接将数据从一个channel 传输到另外一个channel。

transferFrom()

FileChannel的transferFrom()方法可以将数据从源通道传输到FileChannel中

下面的代码实现文件的复制


package com.viashare.channel;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.channels.FileChannel;

/**
 * Created by Jeffy on 16/5/17.
 */
public class ChannelMain {

    private static final String PATH_FROM = "/Users/jeffy-pc/Downloads/test.txt";
    private static final String PATH_TO = "/Users/jeffy-pc/Downloads/test3.txt";

    public static void main(String[] args) throws IOException {
        copy();
    }

    private static final void copy() throws IOException {

        FileInputStream randomAccessFileFrom = new FileInputStream(new File(PATH_FROM));
        FileOutputStream randomAccessFileTo = new FileOutputStream(new File(PATH_TO));
        FileChannel fromchannel = randomAccessFileFrom.getChannel();
        FileChannel tochannel = randomAccessFileTo.getChannel();
        long position = 0;
        long count = fromchannel.size();
        tochannel.transferFrom(fromchannel,position, count);
    }

}


方法的输入参数position表示从position处开始向目标文件写入数据,count表示最多传输的字节数。如果源通道的剩余空间小于 count 个字节,则所传输的字节数要小于请求的字节数。
此外要注意,在SoketChannel的实现中,SocketChannel只会传输此刻准备好的数据(可能不足count字节)。因此,SocketChannel可能不会将请求的所有数据(count个字节)全部传输到FileChannel中。

transferTo()

是不是发现这个例子和前面那个例子特别相似?除了调用方法的FileChannel对象不一样外,其他的都一样。
上面所说的关于SocketChannel的问题在transferTo()方法中同样存在。SocketChannel会一直传输数据直到目标buffer被填满。

 private static final void transferToCopy() throws IOException {
        FileInputStream randomAccessFileFrom = new FileInputStream(new File(PATH_FROM));
        FileOutputStream randomAccessFileTo = new FileOutputStream(new File(PATH_TO));
        FileChannel fromchannel = randomAccessFileFrom.getChannel();
        FileChannel tochannel = randomAccessFileTo.getChannel();
        long position = 0;
        long count = fromchannel.size();
        fromchannel.transferTo(position, count,tochannel);
    }
    

相关文章

  • Java NIO 通道之间的数据传输

    Java NIO 通道之间的数据传输 在Java NIO中,如果两个通道中有一个是FileChannel,那你可以...

  • Java NIO 教程(五) 通道之间的数据传输

    参考:http://ifeve.com/java-nio-channel-to-channel/原文地址 目录 J...

  • Java NIO FileChannel

    Java NIO FileChannel Java NIO FileChannel是连接到文件的通道。 使用文件通...

  • Java NIO Selector

    Java NIO Selector Selector(选择器)是Java NIO中能够检测一到多个NIO通道,并能...

  • Java NIO系列教程(五) 通道之间的数据传输

    在Java NIO中,如果两个通道中有一个是FileChannel,那你可以直接将数据从一个channel(译者注...

  • Java NIO 记录(一)

    一、NIO简介 Java NIO (New IO , Non Blocking IO)。NIO是一个基于通道,...

  • NIO

    一、Java NIO 概述 二、Java NIO vs. IO 三、通道(Channel): 四、缓冲区(Buff...

  • JAVA基础之NIO

    1、Buffer 1.1 概述 Java NIO中的Buffer用于和NIO通道进行交互,是将数据移进移出通道的唯...

  • 三.Buffer

    一.Buffer Java NIO中的Buffer用于和NIO通道进行交互。如你所知,数据是从通道读入缓冲区,从缓...

  • JAVA NIO(二)—Buffer

    一、简介     Java NIO中的Buffer用于和NIO通道进行交互。如你所知,数据是从通道读入缓冲区,从缓...

网友评论

    本文标题:Java NIO 通道之间的数据传输

    本文链接:https://www.haomeiwen.com/subject/eprieftx.html