我有以下代码,在我的班级中逐行读取文件时效果很好。
try { FileInputStream in = new FileInputStream(filename);
BufferedReader reader=new BufferedReader(new InputStreamReader(in));
String line;
while((line=reader.readLine())!=null){
// read the file
}
}
catch (Exception e) {
System.out.println(e);
}
但是如果我尝试添加命令 关闭 ,那么在文件读完之后,我就会收到错误:
in.close();
Error:(131, 9) java: cannot find symbol
symbol: variable in
location: class ReadFile
我在使用后搜索了清洁对象,并且需要在程序结束前关闭文件。并在Java上发现了几个帖子,但很多都非常矛盾。关键是,最后我感到非常困惑。
我错了,或者Java编程有点模糊和混乱?我的意思是,显然没有真正使用destructor,finalize的使用非常值得怀疑,并且close的使用也被认为是不必要的。关于这些问题的一些帖子是矛盾和无定论的。
那么,如何在这里继续?在我真的需要关闭文件的情况下,如何摆脱这个错误信息?关闭文件真的可有可无和不必要吗?如何清理程序完成的类实例?
答案 0 :(得分:5)
你可能会关闭in.close()
一边尝试阻止,所以很明显你会收到错误,因为在本地的try块中定义了in
。
最好使用try with resource,这样您就不需要手动关闭文件流
答案 1 :(得分:5)
您收到错误是因为您在try块中定义了变量in
,因此它在catch / finally /或try之外的任何地方都不可见。将声明移到try:
更改此
try { FileInputStream in = new FileInputStream(filename);
到
FileInputStream in = null;
try { in = new FileInputStream(filename);
答案 2 :(得分:1)
理想情况下,在close()
检查后,您必须在finally
块内调用null
方法。
为此,您需要在in
块之外声明变量try
。
调用close()
块中的finally
方法可以确保调用它,而不管try
块中的代码是否抛出异常。
编辑:这是您使用Java 6或更早版本的时候。对于Java 7及更高版本,您可以按照@JqueryLearner
的建议使用尝试使用资源