流的关闭
当使用完流后,显示的关闭所有打开的流仍然是一个好习惯。一个被打开的流有可能会用尽系统的资源,这取决于平台和实现。如果没有将流关闭,另一个程序试图打开另一个流时,可能会得到不需要的资源。
从JDK1.7后,有两种关闭数据流的方法,分别如下:
方法一:手动关闭。即为使用close()显式地关闭流,代码如下
package com.qfstu.Week04.Day01; import java.io.FileInputStream; import java.io.IOException; /** * @Author bolin * @Description TODO * @Date 2022/3/21 19:34 * @Version 1.0 */ public class TestFileInputStream01 { public static void main(String[] args) { //注意:此处需要提前声明局部变量 并初始化为空 //否则下方的 finally处无法使用fis.close关闭流 FileInputStream fis = null; try { fis = new FileInputStream("D:\\Test01.txt"); //此处可以实现对流的操作 此处省略 //此处默认会生成IOException、FileNotFoundException等异常 较为繁琐 //可以直接捕捉父类异常 Exception } catch (Exception e) { //打印异常信息 e.printStackTrace(); //由于finally一定执行 故将关闭流操作放到finally语句块中 } finally { //如果文件输入流不是null 关闭流 if(fis != null) { try { fis.close(); } catch (IOException e) { e.printStackTrace(); } } } } }
方法二:自动关闭。即为使用try语句自动关闭流,代码如下:
package com.qfstu.Week04.Day01; import java.io.FileInputStream; /** * @Author 25741 * @Description TODO * @Date 2022/3/21 19:40 * @Version 1.0 */ public class TestFileInputStream02 { public static void main(String[] args) { //直接在try()中创建流对象 会默认关闭 try (FileInputStream fis = new FileInputStream("D:\\Test01.txt")) { //读写操作 此处省略 //详细解释见上面代码块 }catch(Exception e) { e.printStackTrace(); } } }
注:使用IDEA书写代码时,使用快捷键 alt+enter 处理异常时经常遇到如下选项:
四个选项中此处只介绍一种抛出异常和两种捕捉异常
* 选项1、Add... ... 代表抛出异常 选择使用throws抛出异常时候则必须close()方法关闭流 * 选项2、Surround... ... 代表生成 try{ //语句 }catch (Exception e) { //打印异常信息 e.printStackTrace(); } finally{ //关闭流 } * 选项4、Surround... ...代表生成 try(//语句) { //语句 }catch(Exception e) { //打印异常信息 e.printStackTrace(); } 注:try()其中的括号内生成的流对象会默认自动关闭 便是方法二中使用的