参见英文答案 >
Java io ugly try-finally block12个
这是一个代码风格的问题.我注意到很多示例代码,包括一些 examples from Oracle确保流以以下方式关闭:
这是一个代码风格的问题.我注意到很多示例代码,包括一些 examples from Oracle确保流以以下方式关闭:
InputStream in = null; try { in = acquireStream(); ... } finally { if (in != null) in.close(); }
注意初始化为null,并在finally块中检查null.
我倾向于编写如下代码:
InputStream in = acquireStream(); try { ... } finally { in.close(); }
这两种方法都有优点吗?我喜欢我的风格,因为我不需要空的检查.我也想尽可能避免为null.但是,由于Oracle风格在网络示例中非常常见,我想知道我的是否存在一些隐藏的错误.
我对InputStream,OutputStream,java.sql.Connection,java.sql.PreparedStatement等提出了同样的问题.我倾向于在try块之外获取资源,最后在没有空检查的情况下关闭它.除了文体差异外,还有什么我失踪的吗?
谢谢.
解决方法
由于Java 7有一个更好的方式来编写try-finally块关于Closeable资源.
现在,您可以在try关键字之后的括号内创建资源,如下所示:
try (init resources) { ... }
一个例子:
try ( ZipFile zf = new ZipFile(zipFileName); BufferedWriter writer = Files.newBufferedWriter(outputFilePath,charset); ) { // Enumerate each entry for (Enumeration entries = zf.entries(); entries.hasMoreElements();) { // Get the entry name and write it to the output file String newLine = System.getProperty("line.separator"); String zipEntryName = ((java.util.zip.ZipEntry)entries.nextElement()).getName() + newLine; writer.write(zipEntryName,zipEntryName.length()); } }
在for循环完成后,资源将被关闭!