package namespace;import java.io.*;public class IOTest {public static void main(String arg[]) throws IOException {FileReader reader = new FileReader("F:\\java.txt");char buffer[] = new char[1024];int count;while((count=reader.read(buffer))!=-1){//System.out.println(buffer); 當buffer.length= 3 時的輸出//System.out.println(buffer);System.out.println(new String(buffer,0,count));}}}/* * 假定F:\java.txt檔案裡面存放了 abcdefg七個字元,下面我們來讀取它 * 1.如果 buffer length=3,那麼我們一次讀取三個字元 ,如果我們直接輸出System.out.println(buffer),那麼它將輸出的是: * abc * def * gef 為什麼會輸出上面的結果? * 因為不停地向buffer 數組裡面寫進東西,最後一次讀的時候就一個字元g,,所以buffer的第一個元素就是g, * 由於沒有其他的元素而數組後面的元素就沒有被覆蓋 * 2.將 buffer.length= 10 時,輸出的結果為:abcdefg&&& * 為什麼會輸出上面的結果,因為檔案裡面就7個字元,而定義的buffer.length = 10 ,所以一次就可以讀取完 了,而 * 把讀取的字元放在buffer 的前七個元素,而後面的幾個位置並沒有其他元素,所以不會輸出不確定的東西 * * * +++++++++++ * 那麼要在檔案大小 不確定的時候,要怎麼確定緩衝區 buffer 的大小呢.??? * 一般在設定的時候都把buffer.length 設定成 1024 的倍數,而為了能正確的輸出,一般我們都採用下面的格式 : * System.out.println(new String(buffer,0,count)); * 2011/10/30 19:19:48 * */