System.in引起的问题


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

相关文章
相关标签/搜索