关于java.io.EOFException产生的原因以及解决方案
java.io.EOFException产生的原因及解决
异常发生场景
使用ObjectInputStream类往文件中传入自定义类student时
ObjectInputStream objectInputStream=null;
ArrayList<Student> students=null;
try {
objectInputStream = new ObjectInputStream(new FileInputStream("D:\\桌面\\java38\\javase08\\java08\\1.txt"));
students = (ArrayList<Student>) objectInputStream.readObject();
System.out.println("数据载入成功");
}catch (Exception e) {
e.printStackTrace();
System.out.println("数据载入失败");
}异常产生原因
经过导师查找,终于发现了OFException产生的原因
ObjectInputStream objectInputStream=null;
//idea上显示null为灰色,说明 new ObjectInputStream(new FileInputStream("D:\\桌面\\java38\\javase08\\java08\\1.txt"));返回值为null,即文件"D:\\桌面\\java38\\javase08\\java08\\1.txt"为空
objectInputStream = new ObjectInputStream(new FileInputStream("D:\\桌面\\java38\\javase08\\java08\\1.txt"));objectInputStream为空值,则不能使用objectInputStream.close();如果使用会产生并发症 java.lang.NullPointerException(空指针异常)
异常解决
ObjectInputStream objectInputStream=null;
ArrayList<Student> students=null;
try {
objectInputStream = new ObjectInputStream(new FileInputStream("D:\\桌面\\java38\\javase08\\java08\\1.txt"));
students = (ArrayList<Student>) objectInputStream.readObject();
System.out.println("数据载入成功");
} catch (EOFException e) {
students = new ArrayList<>();
}catch (Exception e) {
e.printStackTrace();
System.out.println("数据载入失败");
} finally {
if(objectInputStream != null) {
objectInputStream.close();
}在finally语句内加上判断,不等于空值才关闭
捕获EOFException,但不打印错误,为students,new一个新的集合(本来这里也有一个会出bug的地方,但是被我之前就给students赋了null值,(ArrayList<Student> students=null;)所以catch里new一个新的对象)
如果不为空,则
students = (ArrayList<Student>) objectInputStream.readObject();
正常执行,不报错误~
总结
java.io.EOFException不是一个常出现的问题,而且并发症 java.lang.NullPointerException(空指针异常),只有objectInputStream.readObject();接收为null且1.txt文件为空时才会出现
EOFException只需要捕获,该bug在本场景下被捕获后程序就不会终止了,甚至不处理也行。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
SpringBoot使用swagger生成api接口文档的方法详解
在之前的文章中,使用mybatis-plus生成了对应的包,在此基础上,我们针对项目的api接口,添加swagger配置和注解,生成swagger接口文档,需要的可以了解一下2022-10-10
SpringBoot基于Mybatis拦截器和JSqlParser实现数据隔离
本文将介绍如何在 Spring Boot 项目中利用Mybatis的强大拦截器机制结合JSqlParser,一个功能丰富的 SQL 解析器,来轻松实现数据隔离的目标,本文根据示例展示如何根据当前的运行环境来实现数据隔离,需要的朋友可以参考下2024-04-04


最新评论