上学的时候,也许老师告诉你用完文件流记得要关闭,可能为了省事,他也没仔细的给你示范如何关闭,
实际开发中,要是不能正确关闭流,服务器分分钟炸掉,那是很正常的。
一般都是新人才会有这个问题。当然都是从新人走过来的嘛。
下面是大师兄总结的关闭文件流的基本动作,有不合适的,还请指出来。
流在try外面声明,在try里面初始化,然后在finally里面给close,还记得处理异常e
finally里面close的时候也得再次try catch 一下。
具体代码和具体的解释如下:
/**
* 测试正确关闭文件流
*/
private static void testCloseFileStream() {
final Logger LOG = LoggerFactory.getLogger(Cmshome.class);
String fileName = "";
InputStream inputStream = null;//声明个引用,因为这个new对象的时候也是会异常的
try {
//这里就会异常,如果文件名不存在的话。
inputStream = new FileInputStream(fileName);
} catch (IOException e) {
//这个主要是把出现的异常给人看见,不然就算异常了,看不到就找不到问题所在。
LOG.debug("loadProperties IOException:" + e.getMessage());
} finally {
if (inputStream != null) {
try {
inputStream.close(); // 关闭流
} catch (IOException e) {
LOG.debug("inputStream close IOException:" + e.getMessage());
}
}
}
}
//错误的关闭文件的方式的解释:
Properties properties = new Properties();
try {
//这要是异常,直接就到catch语句,下面的close就不会执行啦,关闭就没用啦
InputStream wrongWay = new FileInputStream(fileName);
properties.load(wrongWay);
wrongWay.close(); // 关闭流
} catch (IOException e) {
e.printStackTrace();
}
//下面是new文件流和关闭文件流的源码,有抛异常动作。
public FileInputStream(String name) throws FileNotFoundException {
this(name != null ? new File(name) : null);
}
//这个是抽象类(abstract class)里面的方法,所以没有具体实现过程。
public void close() throws IOException {}
关于一楼的留言的更新:
这是我的代码,是经过debugs分析的,就一条红线。
然后下面是这个红线的详细描述。
他说的这个是编码的问题,说,我这个读文件的操作,是按默认的编码读的,警告我,选个好点的api,设置上指定的api,这样就可以很好的跨平台使用。并没有说,这个关文件流的毛病。