1. 本章学习总结
2. 书面作业
Q1.常用异常
题目5.1
**1.1截图你的提交结果(出现学号)
1.2自己以前编写的代码中经常出现什么异常、需要捕获吗(为什么)?应如何避免?
引用数组元素是常出现下标越界,该一场属于于RuntimeException异常,无需捕获,加长数组长度即可避免。
1.3 什么样的异常要求用户一定要使用捕获处理?
除了RuntimeException异常,其他异常都需要捕获处理。
Q2.处理异常使你的程序更加健壮
题目5.2
2.1截图你的提交结果(出现学号)
2.2 实验总结
输入整数放入数组时,应该把数组下标得递增放在try里,这样就可以在出现异常时再次输入放到数组的连续位置。
若输入非整型字符串,会抛出NumberFormatException异常。
Q3.throw与throws
题目5-3
3.1截图你的提交结果(出现学号)
3.2阅读Integer.parsetInt源代码,结合3.1说说抛出异常时需要传递给调用者一些什么信息?
将一个格式不正确的字符串转换为整型时会出现错误,将NumberFormatException异常通过throws抛出。
Q4.函数题
题目4-1(多种异常的捕获)
4.1截图你的提交结果(出现学号)
4.2 一个try块中如果可能抛出多种异常,捕获时需要注意些什么?
需要注意异常类的继承关系,子类异常必须放在父类异常前面。
Q5.为如下代码加上异常处理
byte[] content = null;
FileInputStream fis = new FileInputStream("testfis.txt");
int bytesAvailabe = fis.available();//获得该文件可用的字节数
if(bytesAvailabe>0){
content = new byte[bytesAvailabe];//创建可容纳文件大小的数组
fis.read(content);//将文件内容读入数组
}
System.out.println(Arrays.toString(content));//打印数组内容
5.1 改正代码,让其可正常运行。注1:里面有多个方法均可能抛出异常。注2:要使用finally关闭资源。
代码如下:
byte[] content = null;
FileInputStream fis=null;
try {
fis=new FileInputStream("testfis.txt");
int bytesAvailabe = fis.available();//获得该文件可用的字节数
if (bytesAvailabe > 0) {
content = new byte[bytesAvailabe];//创建可容纳文件大小的数组
fis.read(content);//将文件内容读入数组
}
System.out.println(Arrays.toString(content));//打印数组
}
catch(FileNotFoundException ex)
{
System.out.println(ex);
}
catch(IOException ex)
{
System.out.println(ex);
}
finally {
System.out.println("关闭资源");
try
{
fis.close();
} catch(IOException ex){
}
}
5.2使用Java7中的try-with-resources来改写上述代码实现自动关闭资源.
public static void main(String[] args) throws IOException {
byte[] content = null;
try(FileInputStream fis = new FileInputStream("testfis.txt");) {
int bytesAvailabe = fis.available();// 获得该文件可用的字节数
if (bytesAvailabe > 0) {
content = new byte[bytesAvailabe];// 创建可容纳文件大小的数组
fis.read(content);// 将文件内容读入数组
}
System.out.println(Arrays.toString(content));// 打印数组内容
}
}