在try-catch机制优化IO流关闭时,OutputStreamWriter 数据流被截断
IO 优化 机制 关闭 try 数据流 catch 截断
2023-09-11 14:18:07 时间
1.前言
try-catch常规的格式是try{……}catch(){……}finallly{……},如果优化成try(……){……}catch(){……}finallly{……},此时流就可以自动关闭,不需要手动去关闭。
2.样例分析
try-catch优化前,代码如下:
try { FileOutputStream fos = new FileOutputStream(f); Writer out = new OutputStreamWriter(fos, "UTF8"); out.write(str); out.close(); }catch (IOException e) { LOG.error(e.getMessage(), e); }
优化try-catch后,代码如下:
try(FileOutputStream fos = new FileOutputStream(f);){ Writer out = new OutputStreamWriter(fos, "UTF8"); out.write(str); out.flush(); } catch (IOException e) { LOG.error(e.getMessage(), e); }
但是写到文件的数据被截断,原因是try(code){},会自动执行out.close()方法时,数据还在缓冲区,还没有完全写入到文件中,因此产生这个问题。只需要添加out.flush()把缓冲区的数据刷到文件即可。
try(FileOutputStream fos = new FileOutputStream(f);){ Writer out = new OutputStreamWriter(fos, "UTF8"); out.write(str); out.flush(); }
3.总结
其它Writer的子类遇到此问题,也可以如此处理。
相关文章
- com.jcraft.jsch.JSchException: Session.connect: java.io.IOException: End of IO Stream Read
- java基础—IO流——字节流的操作演示
- python中IO库中StringIO方法和BytesIO方法用法详解
- 第七章 Caché 变量大全 $IO 变量
- 块设备IO优化的典型案例分析
- java.io.IOException: There appears to be a gap in the edit log. We expected txid ***, but got txid
- 非io优化实例CentOS 7系统 4G内存 free -m 显示内存3.5g左右
- Caused by: io.jsonwebtoken.security.WeakKeyException: The specified key byte array is 224 bits which
- 详解IO多路复用机制——select、poll、epoll的原理和区别
- 详解文件IO操作
- IO文件
- spring源码分析之spring-core-io
- C语言学习笔记 ——格式化IO(二)
- RIFT.io与风河携手促进NFV解决方案部署
- Caused by: java.io.IOException: 远程主机强迫关闭了一个现有的连接。