今天学到了一个文件读操作的技巧,分享出来大家一起学习~
文件读的时候,一般情况下会创建一个数组,用来存文件内容,如下:
try(FileInputStream fis = new FileInputStream(f);){
byte[] fileContent = new byte[(int) f.length()]; //(int)f.length()可以用fis.available()替代
fis.read(fileContent);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
fis.close();
}
但是,我们假设一种情况,如果文件内容很大,那么这个byte[]数组就会很大,对内存占用就会很大,所以有了一种新的思路:每KB读取,再拼接如下:
try(FileInputStream fis = new FileInputStream(f);){
byte []b = new byte[1024];//创建一个容量为1KB的字节数组
StringBuffer str = new StringBuffer();//创建缓冲字符串,用于后续字符串的拼接
int len = 0;
while((len = fis.read(b)) != -1){ //fis.read(b)可以从包含的输入流中读取一定数量的字节,并将它们存储到缓冲区数组 b 中。以整数形式返回实际读取的字节数。如果因为流位于文件末尾而没有字节可用,则返回值 -1
String s = new String(b,0,len); //为了解决最后一次读取不足1KB的情况,或者是初始文件大小不足1KB的情况
str.append(s);
}
System.out.println(str);
}catch(IOException e){
e.printStackTrace();
}