1、目的:读取该路径下的log.txt文件 C:\Users\Lyndee\Desktop
2、实现
File f = new File("C:\\Users\\Lyndee\\Desktop\\log.txt");
InputStreamReader isr = new InputStreamReader(new FileInputStream(f));
BufferedReader br = new BufferedReader(isr);
到底为什么读一行要这么麻烦呢,
FileInputStream,InputStreamReader BufferedReader 包这么多层是为啥呢?
请看解析
3、解析
1、
File f = new File("C:\\Users\\Lyndee\\Desktop\\log.txt");
首先我们把文件就想象成一桶水,这句就表示这桶水所在的位置
2、
InputStreamReader isr = new InputStreamReader(new FileInputStream(f));
(1)从内往外看,首先解析new FileInputStream(f),我们都知道,在计算机中文件是一个字节一个字节的存储,而FileInputStream在读取文件的时候,就是一个字节一个字节的读取的。也就是我们用FileInputStream将桶里的水,一滴一滴的放到另一个桶中。
但是一滴一滴是非常麻烦,而且也不易于我们看懂,所以我们要将一个一个的字节读取,转换为字符读取,也就是InputStreamReader
(2)InputStreamReader:他就是字节转换为字符的桥梁,相当于本来是一滴一滴的水,现在转换为一瓢一瓢的水。
BufferedReader br = new BufferedReader(isr);
但是呢,InputStreamReader没有readLine()方法,而我们的日志文件是需要分行读取的,所以我们还需要包一层BufferedReader。让文件能够一行一行的读取出来。