Java: 复制文件最快方法
利用Java复制文件到处都可以用到,这里总结了一个类供大家参考。里面总共有两个方法:
public static boolean copyFile(String srcFileName, String destFileName,boolean overlay);
public static boolean copyDirectory(String srcDirName, String destDirName,boolean overlay) ;
其中:
srcFileName 待复制的文件名
descFileName 目标文件名
overlay 如果目标文件存在,是否覆盖
如果复制成功返回true,否则返回false
代码:
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.FileNotFoundException;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.io.OutputStream;
- import javax.swing.JOptionPane;
- /**
- * 复制文件或文件夹
- *
- * zww
- */
- public class CopyFileUtil {
- private static String MESSAGE = "";
- /**
- * 复制单个文件
- *
- * @param srcFileName
- * 待复制的文件名
- * @param descFileName
- * 目标文件名
- * @param overlay
- * 如果目标文件存在,是否覆盖
- * @return 如果复制成功返回true,否则返回false
- */
- public static boolean copyFile(String srcFileName, String destFileName,
- boolean overlay) {
- File srcFile = new File(srcFileName);
- // 判断源文件是否存在
- if (!srcFile.exists()) {
- MESSAGE = "源文件:" + srcFileName + "不存在!";
- JOptionPane.showMessageDialog(null, MESSAGE);
- return false;
- } else if (!srcFile.isFile()) {
- MESSAGE = "复制文件失败,源文件:" + srcFileName + "不是一个文件!";
- JOptionPane.showMessageDialog(null, MESSAGE);
- return false;
- }
- // 判断目标文件是否存在
- File destFile = new File(destFileName);
- if (destFile.exists()) {
- // 如果目标文件存在并允许覆盖
- if (overlay) {
- // 删除已经存在的目标文件,无论目标文件是目录还是单个文件
- new File(destFileName).delete();
- }
- } else {
- // 如果目标文件所在目录不存在,则创建目录
- if (!destFile.getParentFile().exists()) {
- // 目标文件所在目录不存在
- if (!destFile.getParentFile().mkdirs()) {
- // 复制文件失败:创建目标文件所在目录失败
- return false;
- }
- }
- }
- // 复制文件
- int byteread = 0; // 读取的字节数
- InputStream in = null;
- OutputStream out = null;
- try {
- in = new FileInputStream(srcFile);
- out = new FileOutputStream(destFile);
- byte[] buffer = new byte[1024];
- while ((byteread = in.read(buffer)) != -1) {
- out.write(buffer, 0, byteread);
- }
- return true;
- } catch (FileNotFoundException e) {
- return false;
- } catch (IOException e) {
- return false;
- } finally {
- try {
- if (out != null)
- out.close();
- if (in != null)
- in.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- }
- /**
- * 复制整个目录的内容
- *
- * @param srcDirName
- * 待复制目录的目录名
- * @param destDirName
- * 目标目录名
- * @param overlay
- * 如果目标目录存在,是否覆盖
- * @return 如果复制成功返回true,否则返回false
- */
- public static boolean copyDirectory(String srcDirName, String destDirName,
- boolean overlay) {
- // 判断源目录是否存在
- File srcDir = new File(srcDirName);
- if (!srcDir.exists()) {
- MESSAGE = "复制目录失败:源目录" + srcDirName + "不存在!";
- JOptionPane.showMessageDialog(null, MESSAGE);
- return false;
- } else if (!srcDir.isDirectory()) {
- MESSAGE = "复制目录失败:" + srcDirName + "不是目录!";
- JOptionPane.showMessageDialog(null, MESSAGE);
- return false;
- }
- // 如果目标目录名不是以文件分隔符结尾,则加上文件分隔符
- if (!destDirName.endsWith(File.separator)) {
- destDirName = destDirName + File.separator;
- }
- File destDir = new File(destDirName);
- // 如果目标文件夹存在
- if (destDir.exists()) {
- // 如果允许覆盖则删除已存在的目标目录
- if (overlay) {
- new File(destDirName).delete();
- } else {
- MESSAGE = "复制目录失败:目的目录" + destDirName + "已存在!";
- JOptionPane.showMessageDialog(null, MESSAGE);
- return false;
- }
- } else {
- // 创建目的目录
- System.out.println("目的目录不存在,准备创建。。。");
- if (!destDir.mkdirs()) {
- System.out.println("复制目录失败:创建目的目录失败!");
- return false;
- }
- }
- boolean flag = true;
- File[] files = srcDir.listFiles();
- for (int i = 0; i < files.length; i++) {
- // 复制文件
- if (files[i].isFile()) {
- flag = CopyFileUtil.copyFile(files[i].getAbsolutePath(),
- destDirName + files[i].getName(), overlay);
- if (!flag)
- break;
- } else if (files[i].isDirectory()) {
- flag = CopyFileUtil.copyDirectory(files[i].getAbsolutePath(),
- destDirName + files[i].getName(), overlay);
- if (!flag)
- break;
- }
- }
- if (!flag) {
- MESSAGE = "复制目录" + srcDirName + "至" + destDirName + "失败!";
- JOptionPane.showMessageDialog(null, MESSAGE);
- return false;
- } else {
- return true;
- }
- }
- public static void main(String[] args) {
- String srcDirName = "C:/test/test0/test1";
- String destDirName = "c:/ttt";
- CopyFileUtil.copyDirectory(srcDirName, destDirName, true);
- }
- }
不考虑多线程优化,单线程文件复制最快的方法是(文件越大该方法越有优势,一般比常用方法快30+%):
- private static void nioTransferCopy(File source, File target) {
- FileChannel in = null;
- FileChannel out = null;
- FileInputStream inStream = null;
- FileOutputStream outStream = null;
- try {
- inStream = new FileInputStream(source);
- outStream = new FileOutputStream(target);
- in = inStream.getChannel();
- out = outStream.getChannel();
- in.transferTo(0, in.size(), out);
- } catch (IOException e) {
- e.printStackTrace();
- } finally {
- close(inStream);
- close(in);
- close(outStream);
- close(out);
- }
- }
如果需要监测复制进度,可以用第二快的方法(留意buffer的大小,对速度有很大影响):
- private static void nioBufferCopy(File source, File target) {
- FileChannel in = null;
- FileChannel out = null;
- FileInputStream inStream = null;
- FileOutputStream outStream = null;
- try {
- inStream = new FileInputStream(source);
- outStream = new FileOutputStream(target);
- in = inStream.getChannel();
- out = outStream.getChannel();
- ByteBuffer buffer = ByteBuffer.allocate(4096);
- while (in.read(buffer) != -1) {
- buffer.flip();
- out.write(buffer);
- buffer.clear();
- }
- } catch (IOException e) {
- e.printStackTrace();
- } finally {
- close(inStream);
- close(in);
- close(outStream);
- close(out);
- }
- }
常用的方法1是:
- private static void customBufferBufferedStreamCopy(File source, File target) {
- InputStream fis = null;
- OutputStream fos = null;
- try {
- fis = new BufferedInputStream(new FileInputStream(source));
- fos = new BufferedOutputStream(new FileOutputStream(target));
- byte[] buf = new byte[4096];
- int i;
- while ((i = fis.read(buf)) != -1) {
- fos.write(buf, 0, i);
- }
- }
- catch (Exception e) {
- e.printStackTrace();
- } finally {
- close(fis);
- close(fos);
- }
- }
常用的方法2是:
- private static void customBufferStreamCopy(File source, File target) {
- InputStream fis = null;
- OutputStream fos = null;
- try {
- fis = new FileInputStream(source);
- fos = new FileOutputStream(target);
- byte[] buf = new byte[4096];
- int i;
- while ((i = fis.read(buf)) != -1) {
- fos.write(buf, 0, i);
- }
- }
- catch (Exception e) {
- e.printStackTrace();
- } finally {
- close(fis);
- close(fos);
- }
- }
Java: 复制文件最快方法的更多相关文章
- Java 复制文件的高效方法
转载自:http://jingyan.baidu.com/article/ff4116259c2d7712e4823780.html 在Java编程中,复制文件的方法有很多,而且经常要用到.我以前一直 ...
- JAVA复制文件最快的算法
/** * 复制文件 * * @param srcFile * 源文件File * @param destDir * 目标目录File * @param newFileName * 新文件名 * @r ...
- Java复制文件用数据流方法,renameTO()方法是相当于剪切操作
我想达到的效果是,一个文件复制到另一个地方,然后重命名 //判断是否存在 File file = new File("D:/tomcat9.0.12/apache-tomcat-9.0.12 ...
- java复制文件夹及所有子目录和文件
package text; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; im ...
- java复制文件的4种方式
尽管Java提供了一个可以处理文件的IO操作类.但是没有一个复制文件的方法.复制文件是一个重要的操作,当你的程序必须处理很多文件相关的时候.然而有几种方法可以进行Java文件复制操作,下面列举出4中最 ...
- [JAVA]java复制文件的4种方式
尽管Java提供了一个可以处理文件的IO操作类. 但是没有一个复制文件的方法. 复制文件是一个重要的操作,当你的程序必须处理很多文件相关的时候. 然而有几种方法可以进行Java文件复制操作,下面列举出 ...
- 4种java复制文件的方式
尽管Java提供了一个可以处理文件的IO操作类,但是没有一个复制文件的方法.复制文件是一个重要的操作,当你的程序必须处理很多文件相关的时候.然而有几种方法可以进行Java文件复制操作,下面列举出4中最 ...
- java复制文件
package com.test.tes; import java.io.File; import java.io.FileInputStream; import java.io.FileOutput ...
- 不能往Windows Server 2008 R2 Server中复制文件的解决方法
目前一直直接往Windows 2008 R2 Server中复制文件(暂时还没有搭建ftp服务),突然不能复制了,于是百度找到了解决方法,特此记录(记忆). 1.在任务管理器中找到“rdpclip.e ...
随机推荐
- 矩阵链乘(UVa 442)
结构体 struct matrix 用来保存矩阵的行和列: map<string,matrix> 用来保存矩阵名和相应的行列数: stack<string> 用来保存表达式中遇 ...
- Codeforces Round #239 (Div. 1) 二项式差分
C - Curious Array 思路:对于区间[l, r]每个数加上C(i - l + k, k), 可以在l处+1, 在r+1处-1, 然后做k+1次求前缀和操作,然后就可以写啦. 然后逐层求前 ...
- linux kernel.shmall shemax shemin解释
Linux X86-64操作系统,Oracle 10g数据库,由8G加到16G,把kernel.shmmax参数改到17179869184(16G)后,发现只要修改sga_max_size和s ...
- Dubbo中只订阅与只注册
一:只订阅 1.场景 为方便开发测试,经常会在线下共用一个所有服务可用的注册中心,这时,如果一个正在开发中的服务提供者注册,可能会影响消费者不能正常运行. 可以让服务提供者开发方,只订阅服务(开发的服 ...
- Windows下的Apache
https://blog.csdn.net/weixin_39082031/article/details/79088800
- ECSHOP中 {insert name='ads' id=$ads_id num=$ads_num}含义
<div class="smallban"> <ul> <!-- TemplateBeginEditabl ...
- poi类包对比
- JDK源码分析(三)——HashMap 上(基于JDK7)
目录 HashMap概述 内部字段及构造方法 存储元素 扩容 取出元素 删除元素 判断 总结 HashMap概述 前面我们分析了基于数组实现的ArrayList和基于双向链表实现的LinkedLi ...
- DHTML和HTML有什么区别?有什么不同
DHTML和HTML有什么区别?有什么不同 首先Dynamic HTML是一种制作网页的方式,而不是一种网络技术(就像JavaScript和ActiveX):它也不是一个标记.一个插件或者是一个浏览器 ...
- fiddler 手机装证书
1: 打开浏览器的地址 输入fiddler 右上方的地址 172.21.14.197:8888 2: 然后点击页面里的 FiddlerRoot certificate 3: 最后验证下 iOS 1 ...