从本地和远程复制文件java 代码

我使用nio和io来测试一个100m的文件,虽然每次速度不同,但是都是io的比nio的快怎么回事。但还是nio 快!!

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;public class CopyFile {
   
/**
     * nio拷贝
     *
@param inFile  源文件
     *
@param outFile 目标文件
     *
@return
     *
@throws Exception
    
*/
   
public static long FileChannelCopy(String inFile,String outFile) throws Exception
    {
       
long begin = System.currentTimeMillis();
        File in
= new File(inFile);   
        File out
= new File(outFile);
        FileInputStream fin
= new FileInputStream(in);
        FileOutputStream fout
= new FileOutputStream(out);
        FileChannel inc
= fin.getChannel();
        FileChannel outc
= fout.getChannel();
       
int bufferLen = 2097152;
        ByteBuffer bb
= ByteBuffer.allocateDirect(bufferLen);
       
while (true)
        {
           
int ret = inc.read(bb);
           
if (ret == -1)
            {     
                fin.close();
                fout.flush();
                fout.close();
               
break;
            }
            bb.flip();
            outc.write(bb);
            bb.clear();
        }
       
long end = System.currentTimeMillis();
       
long runtime = 0;
       
if(end >  begin)
            runtime
= end - begin;
       
return runtime;

    }
   
/**
     * io拷贝
     *
@param inFile 源文件
     *
@param outFile 目标文件
     *
@return
     *
@throws Exception
    
*/
   
public static long FileStraeamCopy(String inFile,String outFile) throws Exception
    {
       
long begin = System.currentTimeMillis();
       
        File in
= new File(inFile);
        File out
= new File(outFile);
        FileInputStream fin
=new FileInputStream(in);
        FileOutputStream fout
=new FileOutputStream(out);
   
       
int length=2097152;//2m内存
        byte[] buffer=new byte[length];
       
       
while(true)
        {
           
int ins=fin.read(buffer);
           
if(ins==-1)
            {
                fin.close();
                fout.flush();
                fout.close();
               
break;
               
            }
else
                fout.write(buffer,
0,ins);
           
        }
       
long end = System.currentTimeMillis();
       
long runtime = 0;
       
if(end > begin)
            runtime
= end - begin;
       
return runtime;

    }
   
static public void main(String args[]) throws Exception {
        String inFile
= "D://big4.pdf"; //源文件
        String outFile = "D://big4copy1.pdf"; //输出文件1
        String outFile2 = "D://big4copy2.pdf"; //输出文件2
        long runtime1,runtime2;
        runtime1
= FileChannelCopy(inFile,outFile);
        runtime2
= FileStraeamCopy(inFile,outFile2);
        System.out.println(
"FileChannelCopy running time:" + runtime1);
        System.out.println(
"FileStraeamCopy running time:" + runtime2);
       
       
       


    }
}

 

 

 

 

 

import java.io.*;
import java.nio.*;
import java.nio.channels.*;

//从得到的耗时结果来看 nio效率高很多!!

public class TestFileChannel {
   
/*
    public static void main(String args[])throws Exception{
         
        ByteBuffer buff=ByteBuffer.allocate(1024);
        FileInputStream fileIn=new FileInputStream("d:/JavaTests/TestFileChannel.txt");
        FileOutputStream fileOut=new FileOutputStream("d:/JavaTests/TestFileChannelOut.txt");
        FileChannel in=fileIn.getChannel();
        FileChannel out=fileOut.getChannel();
        long l=System.currentTimeMillis();
       
        while(in.read(buff)!=-1){
            buff.flip();   //把极限设为位置  再把位置设为0
            out.write(buff);
            buff.clear();    //不改变极限  把位置设为0
        }
       
        System.out.println("Take time:"+(System.currentTimeMillis()-l)+"ms");//31ms
        in.close();
        out.close();
        fileIn.close();
        fileOut.close();
    } 
*/

   
public static void main(String[] args)throws Exception{
       
        FileInputStream fileIn
=new FileInputStream("d:/JavaTests/TestFileChannel.txt");
        FileOutputStream fileOut
=new FileOutputStream("d:/JavaTests/TestFileOutputStreamCopyTime.txt");
       
int i;
       
long l=System.currentTimeMillis();
       
while((i=fileIn.read())!=-1){
            fileOut.write(i);           
        }
        System.out.println(
"Take time:"+(System.currentTimeMillis()-l)+"ms");//516ms
        fileIn.close();
        fileOut.close();
       
    }
       
}

还可以用FileChannel的transferTo(long position, long count, WritableByteChannel target)方法试试!!!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java文件复制(远程复制(网络传输),用于远程备份文件)(支持文件夹,嵌套子文件夹) import java.io.*; import java.util.*; public class FileSelection { private File rootDirectory;//根目录 private File[] fileList;//文件目录下面的文件列表(包括目录,用于多次判断) private ArrayList fileArrayList; // 用于存储文件(只是文件)列表 //初始化参数 public FileSelection() { fileArrayList=new ArrayList(); rootDirectory = new File("Test"); rootDirectory.mkdir(); } //获得文件(不包括目录)的列表 public void initFileArrayList() { if (rootDirectory.isDirectory()) { //遍历目录下面的文件和子目录 fileList = rootDirectory.listFiles(); for (int i = 0; i < fileList.length; i++) { //如果是文件,添加到文件列表中 if(fileList[i].isFile()){ fileArrayList.add(fileList[i]); } //否则递归遍历子目录 else if (fileList[i].isDirectory()) { fileList[i].mkdir(); rootDirectory=fileList[i]; initFileArrayList(); } } } } //将文件信息添加到列表中 public void addFiles(File f){ fileArrayList.add(f); } //访问器返回文件列表 public ArrayList getFileArrayList() { return fileArrayList; } } -------------------- BackupClient.java package com.xinxin.Client; import java.io.*; import java.net.*; /** * * @author Administrator *@version 1.0 *BackupClient类实现文件的传输到服务器 */ public class BackupClient implements Runnable{ private int port;//服务器端口 private InetAddress ipAddress;//服务器IP地址 private Socket clientSocket;//客户端套接字 private InputStream inputStream;//网络输入流 private OutputStream outputStream;//网络输出流 private File file; //构造函数(获得服务器端IP地址和监听端口号) public BackupClient(InetAddress ipAddress,int port,File file){ this.ipAddress=ipAddress; this.port=port;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值