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位置依然有效,例如当读取的字节过多的时候,缓冲区清空重新放置一些内容,那么原来的标志位就失效了,因此有这么个参数。

实际中,这个参数是否有效是取决于两个因素,一个就是参数本身大小,另外一个就是缓冲区的大小。当超过了参数的字节后,因为缓冲区比较大,读写还未超过缓冲区,那么其实标志位是依然有效的,因为缓冲区还是原来的内容,返回后也可以找到原来的位置。