上学的时候,也许老师告诉你用完文件流记得要关闭,可能为了省事,他也没仔细的给你示范如何关闭,
实际开发中,要是不能正确关闭流,服务器分分钟炸掉,那是很正常的。
一般都是新人才会有这个问题。当然都是从新人走过来的嘛。
下面是大师兄总结的关闭文件流的基本动作,有不合适的,还请指出来。

流在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,这样就可以很好的跨平台使用。并没有说,这个关文件流的毛病。


评论关闭
IT序号网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!