好记性不如赖笔头……
/**
* @author Ckinghan
* @描述:使用字节流复制文件与使用高速缓冲流复制文件的对比示例
* WebLogin.log 文件大小:15,028,378 字节(14.3M)
*/
package com.Ckinghan.outputStream;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
/** * @author Ckinghan * @描述:使用字节流复制文件与使用高速缓冲流复制文件的对比示例 * WebLogin.log 文件大小:15,028,378 字节(14.3M) */
public class InputStreamCopyCompared {
public static void main(String[] args) {
long startTime = System.currentTimeMillis();
//字节流复制文件,复制方式:一次读取一个字符
stringFileCopy();
long endTime = System.currentTimeMillis();
System.out.println("字节流复制文件,复制方式:一次读取一个字符耗时:"+(endTime-startTime)+"毫秒复制成功");
startTime = System.currentTimeMillis();
//使用高效缓冲区的字节流读取复制文件,复制方式:一次复制一个字符
bufferedInputStreamReader();
endTime = System.currentTimeMillis();
System.out.println("使用高效缓冲区的字节流读取复制文件,复制方式:一次复制一个字符耗时:"+(endTime-startTime)+"毫秒复制成功");
startTime = System.currentTimeMillis();
//用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节
FileCopy();
endTime = System.currentTimeMillis();
System.out.println("字节流复制文件,复制方式:一次复制指定数量的字节耗时:"+(endTime-startTime)+"毫秒复制成功");
startTime = System.currentTimeMillis();
//用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节
bufferedInputStreamCopyFile();
endTime = System.currentTimeMillis();
System.out.println("用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节耗时:"+(endTime-startTime)+"毫秒复制成功");
}
/** * @描述:字节流复制文件,复制方式:一次读取一个字符 * @创建时间: */
public static void stringFileCopy(){
//创建字节的输出、输出流
InputStream inputStream = null;
OutputStream outputStream = null;
try {
//实例化字节输入、输出流
inputStream = new FileInputStream("E:/WebLogin.log");
outputStream = new FileOutputStream("E:/new3.log");
//创建读取的字节ACSII码
int len = -1;
//循环读取文件数据
while ((len = inputStream.read()) != -1) {
//写入文件
outputStream.write(len);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally {
//如果输出、输入字节流有创建,则关闭,注意关闭顺序,先关输出流再关输入流
try {
if(outputStream != null)
outputStream.close();
if(inputStream != null)
inputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
/** * @描述:字节流复制文件,复制方式:一次复制指定数量的字节 * @创建时间: */
public static void FileCopy(){
//创建流对象
InputStream inputStream = null;
OutputStream stream = null;
try {
//实例化流对象
inputStream = new FileInputStream("E:/WebLogin.log");
stream = new FileOutputStream("E:/new2.log");
//接收读取的字节长度
int len = -1;
//接收读取的字节
byte[] bs = new byte[1024];
//循环读取字节
while((len = inputStream.read(bs)) != -1){
//将读取的字节写入到文件中
stream.write(bs, 0, len);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
//关闭输出流
if(stream != null)
stream.close();
//关闭输入流
if(inputStream != null)
inputStream.close();
} catch (IOException e2) {
e2.printStackTrace();
}
}
}
/** * @描述:用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节 * @创建时间: */
public static void bufferedInputStreamCopyFile(){
//创建字节流对象
InputStream inputStream = null;
OutputStream outputStream = null;
try {
//实例化高效缓冲区字节流的输入、输出对象
inputStream = new BufferedInputStream(new FileInputStream("E:/WebLogin.log"));
outputStream = new BufferedOutputStream(new FileOutputStream("E:/new.log"));
//每次读取的文件字节数量
int len = -1;
//每次读取的文件字节数据
byte[] bs = new byte[1024];
//循环读取文件,直至读到文件末尾
while ((len = inputStream.read(bs)) != -1) {
//写入到文件
outputStream.write(bs, 0, len);
}
//清空缓冲区,将写入到文件中的数据保存
outputStream.flush();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
//关闭流
if(outputStream != null)
outputStream.close();
if(inputStream != null)
inputStream.close();
} catch (IOException e2) {
e2.printStackTrace();
}
}
}
/** * @描述:使用高效缓冲区的字节流读取复制文件,复制方式:一次复制一个字符 * @创建时间: */
public static void bufferedInputStreamReader(){
//创建字节流对象
InputStream inputStream = null;
OutputStream outputStream = null;
try {
//实例化高效缓冲区字节流的输入、输出对象
inputStream = new BufferedInputStream(new FileInputStream("E:/WebLogin.log"));
outputStream = new BufferedOutputStream(new FileOutputStream("E:/login.log"));
//读取的字节ACSII码
int val = -1;
//循环读取文件,直至读到文件末尾
while((val = inputStream.read()) != -1){
//写入到文件
outputStream.write(val);
}
//清空缓冲区,将写入到文件中的数据保存
outputStream.flush();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
//关闭流
if(outputStream != null)
outputStream.close();
if(inputStream != null)
inputStream.close();
} catch (IOException e2) {
e2.printStackTrace();
}
}
}
}
执行结果:
字节流复制文件,复制方式:一次读取一个字符耗时:38814毫秒复制成功
使用高效缓冲区的字节流读取复制文件,复制方式:一次复制一个字符耗时:146毫秒复制成功
字节流复制文件,复制方式:一次复制指定数量的字节耗时:72毫秒复制成功
用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节耗时:37毫秒复制成功
可以看出,使用了高速缓冲流复制文件,所用时间比之未使用之前的相对较少,而且文件越大,差距越大。