Java IO编程——文件拷贝
在操作系统里面有一个copy命令,这个命令的主要功能是可以实现文件的拷贝处理,现在要求模拟这个命令,通过初始化参数输入拷贝的源文件路径与拷贝的目标路径实现文件的拷贝处理。
需求分析:
·需要实现文件的拷贝操作,那么这种拷贝就有可能拷贝各种类型的文件,所以肯定使用字节流;
·在进行拷贝的时候有可能需要考虑到大文件的拷贝问题;
实现方案:
·方案一:使用InputStream将全部要拷贝的内容直接读取到程序里面,而后一次性的输出到目标文件;
|- 如果现在拷贝的文件很大,基本上程序就死了;
·方案二:采用部分拷贝,读取一部分输出一部分数据,如果现在要采用第二种做法,核心的操作方法:
|- InputStream:public int read(byte[] b) throws IOException;
|- OutputStream:public void write(byte[] b,int off, int len) throws IOException;
范例:实现文件拷贝处理
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
class FileUtil { // 定义一个文件操作的工具类
private File srcFile ; // 源文件路径
private File desFile ; // 目标文件路径
public FileUtil(String src,String des) {
this(new File(src),new File(des)) ;
}
public FileUtil(File srcFile,File desFile) {
this.srcFile = srcFile ;
this.desFile = desFile ;
}
public boolean copy() throws Exception { // 文件拷贝处理
if (!this.srcFile.exists()) { // 源文件必须存在!
System.out.println("拷贝的源文件不存在!");
return false ; // 拷贝失败
}
if (!this.desFile.getParentFile().exists()) {
this.desFile.getParentFile().mkdirs() ; // 创建父目录
}
byte data [] = new byte[1024] ; // 开辟一个拷贝的缓冲区
InputStream input = null ;
OutputStream output = null ;
try {
input = new FileInputStream(this.srcFile) ;
output = new FileOutputStream(this.desFile) ;
int len = 0 ;
// 1、读取数据到数组之中,随后返回读取的个数、len = input.read(data
// 2、判断个数是否是-1,如果不是则进行写入、(len = input.read(data)) != -1
while ((len = input.read(data)) != -1) {
output.write(data, 0, len);
}
return true ;
} catch (Exception e) {
throw e ;
} finally {
if (input != null) {
input.close();
}
if (output != null) {
output.close() ;
}
}
}
}
public class JavaAPIDemo {
public static void main(String[] args) throws Exception {
if (args.length != 2) { // 程序执行出错
System.out.println("命令执行错误,执行结构:java JavaAPIDemo 拷贝源文件路径 拷贝目标文件路径");
System.exit(1);
}
long start = System.currentTimeMillis() ;
FileUtil fu = new FileUtil(args[0],args[1]) ;
System.out.println(fu.copy() ? "文件拷贝成功!" : "文件拷贝失败!");
long end = System.currentTimeMillis() ;
System.out.println("拷贝完成的时间:" + (end - start));
}
}
JavaAPIDemo


但是需要注意的是,以上的做法是属于文件拷贝的最原始的实现,而从JDK1.9开始InputStream和Reader类中都追加有数据转存的处理操作方法:
·InputStream:public long transferTo(OutputStream out) throws IOException;
·Reader:public long transferTo(Writer out) throws IOException;
范例:使用转存的方式处理
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
class FileUtil { // 定义一个文件操作的工具类
private File srcFile ; // 源文件路径
private File desFile ; // 目标文件路径
public FileUtil(String src,String des) {
this(new File(src),new File(des)) ;
}
public FileUtil(File srcFile,File desFile) {
this.srcFile = srcFile ;
this.desFile = desFile ;
}
public boolean copy() throws Exception { // 文件拷贝处理
if (!this.srcFile.exists()) { // 源文件必须存在!
System.out.println("拷贝的源文件不存在!");
return false ; // 拷贝失败
}
if (!this.desFile.getParentFile().exists()) {
this.desFile.getParentFile().mkdirs() ; // 创建父目录
}
InputStream input = null ;
OutputStream output = null ;
try {
input = new FileInputStream(this.srcFile) ;
output = new FileOutputStream(this.desFile) ;
input.transferTo(output) ;
return true ;
} catch (Exception e) {
throw e ;
} finally {
if (input != null) {
input.close();
}
if (output != null) {
output.close() ;
}
}
}
}
public class JavaAPIDemo {
public static void main(String[] args) throws Exception {
if (args.length != 2) { // 程序执行出错
System.out.println("命令执行错误,执行结构:java JavaAPIDemo 拷贝源文件路径 拷贝目标文件路径");
System.exit(1);
}
long start = System.currentTimeMillis() ;
FileUtil fu = new FileUtil(args[0],args[1]) ;
System.out.println(fu.copy() ? "文件拷贝成功!" : "文件拷贝失败!");
long end = System.currentTimeMillis() ;
System.out.println("拷贝完成的时间:" + (end - start));
}
}
JavaAPIDemo
此时千万要注意程序的运行版本问题。如果说现在对此程序要求进一步扩展,可以实现一个文件目录的拷贝呢?一旦进行了文件目录的拷贝还需要拷贝所有的子目录中的文件。
范例:文件夹拷贝
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
class FileUtil { // 定义一个文件操作的工具类
private File srcFile ; // 源文件路径
private File desFile ; // 目标文件路径
public FileUtil(String src,String des) {
this(new File(src),new File(des)) ;
}
public FileUtil(File srcFile,File desFile) {
this.srcFile = srcFile ;
this.desFile = desFile ;
}
public boolean copyDir() throws Exception {
try {
this.copyImpl(this.srcFile) ;
return true ;
} catch (Exception e) {
return false ;
}
}
private void copyImpl(File file) throws Exception { // 递归操作
if (file.isDirectory()) { // 是目录
File results [] = file.listFiles() ; // 列出全部目录组成
if (results != null) {
for (int x = 0 ; x < results.length ; x ++) {
copyImpl(results[x]) ;
}
}
} else { // 是文件
String newFilePath = file.getPath().replace(this.srcFile.getPath() + File.separator, "") ;
File newFile = new File(this.desFile,newFilePath) ; // 拷贝的目标路径
this.copyFileImpl(file, newFile) ;
}
}
private boolean copyFileImpl(File srcFile,File desFile) throws Exception {
if (!desFile.getParentFile().exists()) {
desFile.getParentFile().mkdirs() ; // 创建父目录
}
InputStream input = null ;
OutputStream output = null ;
try {
input = new FileInputStream(srcFile) ;
output = new FileOutputStream(desFile) ;
input.transferTo(output) ;
return true ;
} catch (Exception e) {
throw e ;
} finally {
if (input != null) {
input.close();
}
if (output != null) {
output.close() ;
}
}
} public boolean copy() throws Exception { // 文件拷贝处理
if (!this.srcFile.exists()) { // 源文件必须存在!
System.out.println("拷贝的源文件不存在!");
return false ; // 拷贝失败
}
return this.copyFileImpl(this.srcFile, this.desFile) ;
}
}
public class JavaAPIDemo {
public static void main(String[] args) throws Exception {
if (args.length != 2) { // 程序执行出错
System.out.println("命令执行错误,执行结构:java JavaAPIDemo 拷贝源文件路径 拷贝目标文件路径");
System.exit(1);
}
long start = System.currentTimeMillis() ;
FileUtil fu = new FileUtil(args[0],args[1]) ;
if (new File(args[0]).isFile()) { // 文件拷贝
System.out.println(fu.copy() ? "文件拷贝成功!" : "文件拷贝失败!");
} else { // 目录拷贝
System.out.println(fu.copyDir() ? "文件拷贝成功!" : "文件拷贝失败!");
}
long end = System.currentTimeMillis() ;
System.out.println("拷贝完成的时间:" + (end - start));
}
}
JavaAPIDemo
Java IO编程——文件拷贝的更多相关文章
- Java IO 流-- 文件拷贝
IO流操作套路: 1.创建源: 2.选择流: 3.操作: 4.释放资源 上代码: package com.xzlf.io; import java.io.File; import java.io.Fi ...
- java IO流文件拷贝文件(字符流标准写法)
public static void copyFile2(String path1, String path2) { Reader reader = null; Writer writer = nul ...
- java IO Nio 文件拷贝工具类Files
public static void main(String[] args) throws Exception { Files.copy(Paths.get("file/text.txt&q ...
- java IO流文件拷贝文件(字节流标准写法)
public static void copyFile(String srcPath, String destPath) { FileInputStream fis = null; FileOutpu ...
- Java IO编程全解(一)——Java的I/O演进之路
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7419117.html JDK1.4之前的早期版本,Java对I/O的支持并不完善,开发人员在开发高性能I/O ...
- Java IO编程全解(六)——4种I/O的对比与选型
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7804185.html 前面讲到:Java IO编程全解(五)--AIO编程 为了防止由于对一些技术概念和术语 ...
- Java IO编程全解(五)——AIO编程
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7794151.html 前面讲到:Java IO编程全解(四)--NIO编程 NIO2.0引入了新的异步通道的 ...
- Java IO编程全解(四)——NIO编程
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7793964.html 前面讲到:Java IO编程全解(三)——伪异步IO编程 NIO,即New I/O,这 ...
- Java IO :文件
在java应用程序中,文件是一种常用的数据源或者存储数据的媒介.所以这一小节将会对Java中文件的使用做一个简短的概述.这里只提供一些必要的知识点. 通过Java IO读文件 如果你需要在不同端之间读 ...
随机推荐
- 详解http报文(2)-web容器是如何解析http报文的
摘要 在详解http报文一文中,详细介绍了http报文的文本结构.那么作为服务端,web容器是如何解析http报文的呢?本文以jetty和undertow容器为例,来解析web容器是如何处理http报 ...
- [LeetCode] 1108. Defanging an IP Address
Description Given a valid (IPv4) IP address, return a defanged version of that IP address. A defange ...
- Tomcat7.0.40注册到服务启动报错error Code 1 +connector attribute sslcertificateFile must be defined when using ssl with apr
Tomcat7.0.40 注册到服务启动遇到以下几个问题: 1.启动报错errorCode1 查看日志如下图: 解决办法: 这个是因为我的jdk版本问题,因为电脑是64位,安装的jdk是32位的所以会 ...
- 原生js使用getComputedStyle方法获取CSS内部属性值
在对网页进行调试的过程中,经常会用到js来获取元素的CSS样式, 1.下面的方法只能JS只能获取写在html标签中的写在style属性中的值(style=”…”),而无法获取定义在<style ...
- IT爱心求助站
最近发生的一些事情,让我对自己的专业有了另外一层认识. 小尹同学,你是做软件的是吗?能否帮我看一下我的电脑问题? 老同学,我的电脑安装一个软件这么都装不上,能否帮我看一下呢? 邻居你好,我的手机怎么没 ...
- Ubuntu安装NASM和简单的使用教程
1. 安装 sudo apt-get install nasm 这样nasm就安装好了,终端输入命令: nasm -version 输出版本信息就说明安装成功 2. 使用 创建"hello. ...
- 前端模块化(CommonJs,AMD和CMD)
前端模块规范有三种:CommonJs,AMD和CMD. CommonJs用在服务器端,AMD和CMD用在浏览器环境 AMD 是 RequireJS 在推广过程中对模块定义的规范化产出. CMD 是 S ...
- go-关键字-变量
var 声明变量 const 常量的关键字, 常量不能出现只声明不赋值的情况. 名字首字母为大写的程序实体可以被任何代码包中的代码访问到. 名字首字母为小写的程序实体则只能被同一个代码包中的代 ...
- golang会取代php吗
看看PHP和Golang如何在开发速度,性能,安全性,可伸缩性等方面展开合作. PHP与Golang比较是一个艰难的比较. PHP最初创建于1994年,已有24年.自那时起,由于PHP的开源格式,易用 ...
- [案例分析] 政务云市场面临的复杂格局——重庆政务云模式的启示:多厂商竞争化、PaaS 化
新闻背景: 2019 年 9 月底,重庆市大数据应用发展管理局发布政务云平台采购公告,预算金额为 5000 万元,以上 4 家入选. 最终项目被项目被阿里云.腾讯云.华为云.紫光云 4 家瓜分. 50 ...