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