zoukankan      html  css  js  c++  java
  • Java之IO流的关闭

    1.在finally中关闭流;

    OutputStream out = null;  
    try {  
        out = new FileOutputStream("");  
        // ...操作流代码  
    } catch (Exception e) {  
        e.printStackTrace();  
    } finally {  
        try {  
            if (out != null) {  
                out.close();  
            }  
        } catch (Exception e) {  
            e.printStackTrace();  
        }  
    }  

    2.在关闭多个流时因为嫌麻烦将所有关流的代码丢到一个try中

    OutputStream out = null;  
    OutputStream out2 = null;  
    try {  
        out = new FileOutputStream("");  
        out2 = new FileOutputStream("");  
        // ...操作流代码  
    } catch (Exception e) {  
        e.printStackTrace();  
    } finally {  
        try {  
            if (out != null) {  
                out.close();// 如果此处出现异常,则out2流也会被关闭  
            }  
        } catch (Exception e) {  
            e.printStackTrace();  
        }  
        try {  
            if (out2 != null) {  
                out2.close();  
            }  
        } catch (Exception e) {  
            e.printStackTrace();  
        }  
    }  

    3.在循环中创建流,在循环外关闭,导致关闭的是最后一个流

    for (int i = 0; i < 10; i++) {  
        OutputStream out = null;  
        try {  
            out = new FileOutputStream("");  
            // ...操作流代码  
        } catch (Exception e) {  
            e.printStackTrace();  
        } finally {  
            try {  
                if (out != null) {  
                    out.close();  
                }  
            } catch (Exception e) {  
                e.printStackTrace();  
            }  
        }  
    }  

    4.在Java7中,关闭流这种繁琐的操作就不用我们自己写了

      只要实现的自动关闭接口(Closeable)的类都可以在try结构体上定义,java会自动帮我们关闭,及时在发生异常的情况下也会。可以在try结构体上定义多个,用分号隔开即可,如:

    try (OutputStream out = new FileOutputStream("");OutputStream out2 = new FileOutputStream("")){  
        // ...操作流代码  
    } catch (Exception e) {  
        throw e;  
    }  
  • 相关阅读:
    R语言实现人工神经网络预测实例
    Hive 元数据表结构详解
    距离判别法与R程序实战
    Map端数据倾斜
    cdh5.5.6的hue下用ssh方式运行sqoop
    YARN中内存的设置
    hue同时执行多个任务出现org.apache.hadoop.mapred.TaskAttemptListenerImpl
    CDH5.5.6下R、RHive、RJava、RHadoop安装测试
    [转]值得推荐的C/C++框架和库,包含很多开源项目 (真的很强大)
    GPSD
  • 原文地址:https://www.cnblogs.com/tongxuping/p/8192073.html
Copyright © 2011-2022 走看看