题目:
写一段程序完成一下功能:
1.程序运行开始要求用户输入目标文件的全路径
2.输入文件拷贝到哪个目录下
3.监测文件的类型,以合适的流类型来拷贝文件
(最终效果,用户输入一个文件的全路径 和即将拷贝到的目标目录路径程序
即可自动的分辨文件类型并自动选择使用字节流或字符流来拷贝)
代码实现:
package Test01;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import org.junit.Test;
public class FileTest01 {
@Test
void test01(String filepath,LeiXing l) throws IOException{
String filepath02="C:/Users/dmulcj98/Desktop/"+l.name+l.leixing; //如果文件不存在,则创建
File file=new File(filepath);
File file_02=new File(filepath02);
FileInputStream fileinputstream=new FileInputStream(file);
FileOutputStream fileoutputstream=new FileOutputStream(file_02);
byte[] b =new byte[2048];
int length=0;
while((length=fileinputstream.read(b))!=-1){ //赋值length为读到字节的的长度,在下一行可以调length来决定写入的字节长度
fileoutputstream.write(b, 0, length);
}
fileinputstream.close();
fileoutputstream.close();
}
为了更好的理解并记住上面这段代码的实现方法,我们来看一下这个read方法的API解释:
public int read(byte[] b) throws IOException
-
从此输入流中将最多
b.length
个字节的数据读入一个 byte 数组中。
返回:读入缓冲区的字节总数,如果因为已经到达文件末尾而没有更多的数据,则返回
-1
。
这样我们就理解了为什么用一个while来写上面那段代码,我们定义了一个byte数组长度为2048,显然就算我们把这个长度定的再大,也总会有字更多文章会超出那个范围,而且我们如果定义的很大,在操作小文件时很容易造成资源浪费,所以我们就定一个相对不是很大也不是很小的长度,通过while来调这个read方法,如果没读完,read会返回读入的长度(最多为数组长度),所以在读完整个文章前这个循环不会终止,一旦读完,read返回-1,循环终止; 下面的代码同理
package Test01;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class FileReader_Test {
void filereadertest(String filepath,LeiXing l) throws IOException{
File file=new File(filepath);
File outfile=new File("C:\\Users\\dmulcj98\\Desktop\\"+l.name+l.leixing);
FileReader filereader=new FileReader(file);
FileWriter filewriter = new FileWriter(outfile);
int length = 0;
char[] buffer = new char[1024];
while ((length = filereader.read(buffer)) != -1) {
filewriter.write(buffer, 0, length);
}
filewriter.flush();
filewriter.close();
filereader.close();
}
}
package Test01;
public class LeiXing {
public String leixing;
public String filepath;
public String name;
}
package Test01;
import java.io.IOException;
import java.util.Scanner;
public class Dome {
public static void main(String[] args) throws IOException {
LeiXing file=new LeiXing();
Scanner sc = new Scanner(System.in);
file.filepath= sc.next();
if(file.filepath.endsWith("txt")||file.filepath.endsWith("doc")){//碰到文字类文件定义相应文件名和文件类型,调字符流的方法;
file.leixing=".txt"; //因为前面我们定义方法时是file.name+file.leixing所以我们在这要在类型里加上那个"."
file.name="Txtfuben";
FileReader_Test aa=new FileReader_Test();
aa.filereadertest(file.filepath, file);
}else if(file.filepath.endsWith("png")){ //碰到png类型,其实也可以再写其他类型,调字节流方法;
file.leixing=".png";
file.name="pngfuben";
FileTest01 aa=new FileTest01();
aa.test01(file.filepath,file);
}
}
}
输入:
C:\\Users\\dmulcj98\\Desktop\\Eclipse常用快捷键.png
输出结果:
创建了一个名为“pngfuben.png”的副本文件在桌面
输入:
C:\\Users\\dmulcj98\\Desktop\\test.txt
输出结果:
在桌面创建了一个名为“Txtfuben.txt”的副本文件