文件拷贝功能java实现

简介: 文件拷贝功能java实现

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.StandardCopyOption;

public class FileCopyTest {

    public static void main(String[] args) {
        // 文件大小为4.5G
        
        System.out.println(System.currentTimeMillis());
        // 1595581151315 -- 1595581253196 = 101881ms = 101s
        // copyFile(new File("D:\\xl\\big.mkv"), new File("D:\\big.mkv"));
        // 1595582378585 -- 1595582548529 = 169944ms = 169s
        // fileChannelCopy(new File("D:\\xl\\big.mkv"), new File("D:\\big2.mkv"));
        // 1595582683903 -- 1595582805496 = 121593ms = 121s
        // fileCopy(new File("D:\\xl\\big.mkv"), new File("D:\\big2.mkv"));
        // 1595583767345 -- 1595583897985 = 130640ms = 130s
        // filesCopy(new File("D:\\xl\\big.mkv"), new File("D:\\big2.mkv"));
        //1595584222455 -- 1595584325169 =  102714ms = 102s
        copyBigFile(new File("D:\\xl\\big.mkv"), new File("D:\\big.mkv"));
        System.out.println(System.currentTimeMillis());
    }

    // 单文件复制
    public static boolean copyFile(File fromFile, File toFile) {
        try (FileInputStream in = new FileInputStream(fromFile); FileOutputStream os = new FileOutputStream(toFile);) {
            byte[] b = new byte[1024];
            int n = 0;
            while ((n = in.read(b)) != -1) {
                os.write(b, 0, n);
            }
            in.close();
            os.close();
            System.out.println("文件拷贝结束");
            return true;
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }
    }

    public static boolean filesCopy(File s, File t) {
        Path sourcePath = Paths.get(s.getAbsolutePath());
        Path destinationPath = Paths.get(t.getAbsolutePath());

        try {
            Files.copy(sourcePath, destinationPath, StandardCopyOption.REPLACE_EXISTING);
            return true;
        } catch (IOException e) {
            // something else went wrong
            e.printStackTrace();
        }
        return false;
    }

    public static boolean fileCopy(File s, File t) {
        FileInputStream fi = null;
        FileOutputStream fo = null;
        FileChannel in = null;
        FileChannel out = null;
        try {
            fi = new FileInputStream(s);
            fo = new FileOutputStream(t);
            in = fi.getChannel();// 得到对应的文件通道
            out = fo.getChannel();// 得到对应的文件通道
            long left_size = in.size();
            System.out.println("源文件大小:" + left_size / 1024 / 1024);
            long position = 0;
            while (left_size > 0) {
                long write_size = in.transferTo(position, left_size, out);
                position += write_size;
                left_size -= write_size;
            }
            // in.transferTo(0, in.size(), out);// 连接两个通道,并且从in通道读取,然后写入out通道
            System.out.println("FileChannel文件拷贝结束");
            System.out.println("目标文件大小:" + out.size() / 1024 / 1024);
            return true;
        } catch (IOException e) {
            System.out.print("文件出现拷贝异常:{}" + e.getMessage());
            ;
        } finally {
            try {
                fi.close();
                in.close();
                fo.close();
                out.close();
            } catch (IOException e) {
                System.out.print("文件出现拷贝异常:{}" + e.getMessage());
            }

        }
        return false;
    }

    public static boolean fileChannelCopy(File s, File t) {
        FileChannel in = null;
        FileChannel out = null;
        RandomAccessFile fi = null;
        RandomAccessFile fo = null;
        try {
            if (!t.isFile()) {
                if (!t.createNewFile()) {
                    return false;
                }
            }
            fi = new RandomAccessFile(s, "r");
            fo = new RandomAccessFile(t, "rw");
            in = fi.getChannel();// 得到对应的文件通道
            out = fo.getChannel();// 得到对应的文件通道
            long left_size = in.size();
            long position = 0;
            while (left_size > 0) {
                long write_size = in.transferTo(position, left_size, out);
                position += write_size;
                left_size -= write_size;
            }
            // in.transferTo(0, in.size(), out);// 连接两个通道,并且从in通道读取,然后写入out通道
            System.out.println("FileChannel文件拷贝结束");
            return true;
        } catch (IOException e) {
            System.out.print("文件出现拷贝异常:{}" + e.getMessage());
            ;
        } finally {
            try {
                fi.close();
                in.close();
                fo.close();
                out.close();
            } catch (IOException e) {
                System.out.print("文件出现拷贝异常:{}" + e.getMessage());
            }

        }
        return false;
    }

    public static boolean copyBigFile(File s, File t) {
        FileInputStream fi = null;
        FileOutputStream fo = null;
        FileChannel in = null;
        FileChannel out = null;
        ByteBuffer buffer = ByteBuffer.allocate(10 * 1024);
        try {
            fi = new FileInputStream(s);
            fo = new FileOutputStream(t);
            in = fi.getChannel();// 得到对应的文件通道
            out = fo.getChannel();// 得到对应的文件通道
            while (true) {
                int read = in.read(buffer);
                if (read == -1)
                    break;
                buffer.flip();
                out.write(buffer);
                buffer.clear();
            }
            System.out.println("ByteBuffer文件拷贝结束");
            return true;
        } catch (IOException e) {
            System.err.print("文件出现拷贝异常:{}" + e.getMessage());
        } finally {
            try {
                fi.close();
                in.close();
                fo.close();
                out.close();
            } catch (IOException e) {
                System.err.print("文件出现拷贝异常:{}" + e.getMessage());
            }

        }
        return false;
    }

}

相关文章
|
4月前
|
存储 数据可视化 Java
Java Stream API 的强大功能
Java Stream API 是 Java 8 引入的重要特性,它改变了集合数据的处理方式。通过声明式语法,开发者可以更简洁地进行过滤、映射、聚合等操作。Stream API 支持惰性求值和并行处理,提升了代码效率和可读性,是现代 Java 开发不可或缺的工具。
114 0
Java Stream API 的强大功能
|
5月前
|
安全 Java API
Java中的Lambda表达式:简洁与功能的结合
Java中的Lambda表达式:简洁与功能的结合
489 211
|
5月前
|
前端开发 JavaScript Java
Java 项目实战城市公园信息管理系统开发流程与实用功能实现指南
本系统基于Java开发,采用Spring Boot后端框架与Vue.js前端框架,结合MySQL数据库,构建了一个高效的城市公园信息管理系统。系统包含管理员、用户和保洁人员三大模块,涵盖用户管理、园区信息查询、订票预约、服务管理等功能,提升公园管理效率与服务质量。
202 6
|
5月前
|
安全 Java 数据库
Java 项目实战病人挂号系统网站设计开发步骤及核心功能实现指南
本文介绍了基于Java的病人挂号系统网站的技术方案与应用实例,涵盖SSM与Spring Boot框架选型、数据库设计、功能模块划分及安全机制实现。系统支持患者在线注册、登录、挂号与预约,管理员可进行医院信息与排班管理。通过实际案例展示系统开发流程与核心代码实现,为Java Web医疗项目开发提供参考。
314 2
|
5月前
|
机器学习/深度学习 算法 Java
Java 大视界 -- Java 大数据机器学习模型在生物信息学基因功能预测中的优化与应用(223)
本文探讨了Java大数据与机器学习模型在生物信息学中基因功能预测的优化与应用。通过高效的数据处理能力和智能算法,提升基因功能预测的准确性与效率,助力医学与农业发展。
|
5月前
|
JavaScript Java 微服务
现代化 Java Web 在线商城项目技术方案与实战开发流程及核心功能实现详解
本项目基于Spring Boot 3与Vue 3构建现代化在线商城系统,采用微服务架构,整合Spring Cloud、Redis、MySQL等技术,涵盖用户认证、商品管理、购物车功能,并支持Docker容器化部署与Kubernetes编排。提供完整CI/CD流程,助力高效开发与扩展。
697 64
|
6月前
|
Java API
深入解析Java API中Object类的功能
了解和合理运用 Object类的这些方法,对于编写可靠和高效的Java应用程序至关重要。它们构成了Java对象行为的基础,影响着对象的创建、识别、表达和并发控制。
133 0
|
6月前
|
消息中间件 监控 Java
借助最新技术构建 Java 邮件发送功能的详细流程与核心要点分享 Java 邮件发送功能
本文介绍了如何使用Spring Boot 3、Jakarta Mail、MailHog及响应式编程技术构建高效的Java邮件发送系统,涵盖环境搭建、异步发送、模板渲染、测试与生产配置,以及性能优化方案,助你实现现代化邮件功能。
314 0
|
6月前
|
算法 安全 Java
java中Collections.shuffle方法的功能说明
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,常用于洗牌、抽奖等场景。可选 `Random` 参数支持固定种子以实现可重复的随机顺序。方法直接修改原列表,无返回值。
254 0
|
6月前
|
Java API
Java API中Math类功能全景扫描
在实际使用时,这些方法的精确度和性能得到了良好的优化。当处理复杂数学运算或高精度计算时,`Math`类通常是足够的。然而,对于非常精细或特殊的数学运算,可能需要考虑使用 `java.math`包中的 `BigDecimal`类或其他专业的数学库。
155 11