public class Test1 { public static void main(String[] args) throws IOException { for (int i = 0; i < 5; i++) { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); String readLine = br.readLine(); System.out.println(readLine); br.close(); } } }
import java.io.*; class Inlet { public static void main(String[] args) throws Exception { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); String str = br.readLine(); System.out.println(str); br.close(); BufferedReader bb = new BufferedReader(new InputStreamReader(System.in)); str = bb.readLine(); System.out.println(str); bb.close(); } }
這兩段代碼都會出現問題! java
BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); 與 BufferedReader bb = new BufferedReader(new InputStreamReader(System.in)); 都是由System.in封裝而來,實質並無改變,當你調用br .close(),會自動調用br 的實質System.in.close(),因此對於bb來講它已經關閉了。 而在第一個裏面,你雖然關閉了br,可是第二個是經過new FileInputStream("e:\\lesson\\in.txt")新建的,因此你明白了嗎?關閉流的順序通常遵循:先開後關,後開先關。
封裝的話:先內後外的關 less
由於流的關閉是級聯的。你把br close的時候System.in也被close因此你第一次是成功的後面都會報流已被關閉的異常 spa
不論你new 多少個BufferedReader這些都是外層的緩衝流。也叫高級流。可是實際上底層用的仍是System.in。
這個流被關閉了。你new 多少個BufferedReader有什麼用。我上面就說了這個System.in是System類被加載的時候就分配好的final變量。因此你System.in已經被關閉了。你外層的流在怎麼new也是無用,由於底層的流被關閉了 code
System類暴露了一個setIn方法是能夠用來設置System.in的也就是說你關閉了以後要在用System.setIn放入一個新的的InputStream給System.in io