package com.test.filetest;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.io.Reader;
public class FileMain {
/**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
/*// TODO Auto-generated method stub
File myfile=new File("H:/test.txt");
//FileReader是字符流,每次读入的是两个字节。
FileReader in=new FileReader(myfile);
BufferedReader br=new BufferedReader(in);
String line=null;
while((line=br.readLine())!=null)
{
System.out.println(line);
}
br.close();
in.close();*/
/*声明一个filereader对象*/
FileReader fr=new FileReader("H:/test.txt");
/*声明一个bufferedreader对象,对filereader的一层封装
* 设置的缓冲区大小为2个字节
* */
BufferedReader br=new BufferedReader(fr,2);
System.out.println(br.readLine());
br.mark(2);
System.out.println(br.readLine());
/*缓冲区大小为2个字节,标识可读为两个字节,读取的长度超过2个字节,发生抛出异常*/
br.reset();
System.out.println(br.readLine());
}
}
其中bufferedreader对象中的mark方法,作用是设置一个当前的标志,然后可以使用reset方法来回到这个标志点进行读写。其中mark方法有一个int型的参数,参数的意思是在当前的位置后,可读取的最大字节数,如果超过了该字节,那么bufferedreader对象不保证mark位置依然有效,例如当读取的字节过多的时候,缓冲区清空重新放置一些内容,那么原来的标志位就失效了,因此有这么个参数。
实际中,这个参数是否有效是取决于两个因素,一个就是参数本身大小,另外一个就是缓冲区的大小。当超过了参数的字节后,因为缓冲区比较大,读写还未超过缓冲区,那么其实标志位是依然有效的,因为缓冲区还是原来的内容,返回后也可以找到原来的位置。