一. 本周学习总结
1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容。
二. 书面作业
本次PTA作业题集异常
1. 常用异常
结合题集题目7-1回答
1.1 自己以前编写的代码中经常出现什么异常、需要捕获吗(为什么)?应如何避免?
答:最常出现的一定是NullPointerExceptin
了,它属于Unchecked Exception
,可以不用捕获。避免的话,编写代码的时候多考虑对象有可能为null,其它的话就需要检查代码,修改代码来解决异常。
1.2 什么样的异常要求用户一定要使用捕获处理?
答:除Error
与RuntimeException
以外,其它都是Checked Exception
,都需要用try catch
来捕获
2. 处理异常使你的程序更加健壮
题集题目7-2
2.1 实验总结。并回答:怎么样才能让你的程序更加健壮?
- 实验总结:此题的关键在
int value = Integer.parseInt(line);
这个语句,如果输入的line不是整型,就会出现NumberFormatException
的异常,需要对其进行try catch
。 - 回答问题:让程序更健壮就应该在需要处理异常的地方对异常进行处理,如果编写的程序中有
Checked Exception
,那么我们对其进行处理之后程序就会更加健壮。
3. throw与throws
题集题目7-3
阅读Integer.parsetInt源代码
3.1 Integer.parsetInt一开始就有大量的抛出异常的代码,这种做法有什么好处?
答:
源代码:
public static int parseInt(String s) throws NumberFormatException {
return parseInt(s,10);
}
public static int parseInt(String s, int radix)
throws NumberFormatException
{
/*
* WARNING: This method may be invoked early during VM initialization
* before IntegerCache is initialized. Care must be taken to not use
* the valueOf method.
*/
if (s == null) {
throw new NumberFormatException("null");
}
if (radix < Character.MIN_RADIX) {
throw new NumberFormatException("radix " + radix +
" less than Character.MIN_RADIX");
}
if (radix > Character.MAX_RADIX) {
throw new NumberFormatException("radix " + radix +
" greater than Character.MAX_RADIX");
}
int result = 0;
boolean negative = false;
int i = 0, len = s.length();
int limit = -Integer.MAX_VALUE;
int multmin;
int digit;
if (len > 0) {
char firstChar = s.charAt(0);
if (firstChar < '0') { // Possible leading "+" or "-"
if (firstChar == '-') {
negative = true;
limit = Integer.MIN_VALUE;
} else if (firstChar != '+')
throw NumberFormatException.forInputString(s);
if (len == 1)
throw NumberFormatException.forInputString(s);
i++;
}
multmin = limit / radix;
while (i < len) {
// Accumulating negatively avoids surprises near MAX_VALUE
digit = Character.digit(s.charAt(i++),radix);
if (digit < 0) {
throw NumberFormatException.forInputString(s);
}
if (result < multmin) {
throw NumberFormatException.forInputString(s);
}
result *= radix;
if (result < limit + digit) {
throw NumberFormatException.forInputString(s);
}
result -= digit;
}
} else {
throw NumberFormatException.forInputString(s);
}
return negative ? result : -result;
}
这样可以使Integer.parsetInt
这个方法提供更多的检验异常,会使这个方法更健全。
3.2 结合自己编写的程序与3.1,分析自己编写的方法抛出异常时一般需要传递给调用者一些什么信息?
答:传递给调用者的信息除了根据不同异常有各种不同对应的Exception之外,还会根据实际情况提醒一些信息。
-
结合题集题目7-3:
if(begin>=end)....IllegalArgumentException("begin:"+begin+" >= end:"+end);
、if(begin<0)....IllegalArgumentException("begin:"+begin+" < 0");
虽然都是IllegalArgumentException
,但是根据实际情况是会给传递者不同的信息的。 -
结合3.1中的:传入null的时候
throw new NumberFormatException("null")
;给定的转化进制数超过规定的范围则throw new NumberFormatException("radix " + radix +" greater than Character.MAX_RADIX");
。虽然都是NumberFormatException
,但是根据实际情况是会给传递者不同的信息的。
4. 用异常改进ArrayIntegerStack
题集题目6-3
4.1 结合6-3代码,回答使用抛出异常的方式代表程序运行时出错有什么好处?比单纯的返回错误值,有何优点?
答:对于单纯的返回null代表出错或者返回错误值来说,使用抛出异常的方式,可以让程序使用者更直观清晰的感受到具体出错的原因是什么,像在题6-3中throws FullStackException
和throws EmptyStackException
,栈满和栈空的情况显得更加直观了。
4.2 如果一个方法内部的内码抛出的是RuntimeException类型的异常,那么方法声明是否应该使用throws关键字,如果使用throws关键字声明该方法抛出的异常,能给我们带来什么好处吗?
答:throws
是可以成功抛出这个异常的。好处是调用者能知道它是因为Runtime异常而不是其他类别的异常,更直观一些吧。
5. 函数题-多种异常的捕获
题集题目6-1
5.1 结合6-1代码,回答:一个try块中如果可能抛出多种异常,且异常之间可能有继承关系,捕获时需要注意些什么?
答:一个try块中如果可能抛出多种异常,我们可以对每个异常都提供一个catch块进行处理,捕获时一定要注意让异常的范围按从小到大排列,子类异常在父类异常前。如果子类异常放在父类异常的后面,会导致子类异常的catch块不会被执行。在题目6-1中catch(NumberFormatException e)
和catch(IllegalArgumentException e)
放在前面,catch(Exception e)
应放在最后。
5.2 一个try块中如果可能抛出多种异常,使用Java8的多重异常捕获语法需要注意些什么?
答:java8的多重异常捕获比使用多个catch块方便一些,只需要一个catch块,例如在题6-1中就可以为catch(NumberFormatException | IllegalArgumentException | Exception e)
,但是和多个catch块的逻辑一样,子类还是必须放在父类的前面才可以。
6. 为如下代码加上异常处理
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));//打印数组内容
6.1 改正代码,并增加如下功能。当找不到文件时,需提示用户找不到文件xxx,请重新输入文件名,然后尝试重新打开。 如果是其他异常则提示打开或读取文件失败!。
注1:里面有多个方法均可能抛出异常。
功能2:需要添加finally关闭文件。无论上面的代码是否产生异常,总要提示关闭文件ing。如果关闭文件失败,提示关闭文件失败!
代码如下:
byte[] content = null;
FileInputStream fis = null;
int bytesAvailabe = 0;
try {
fis = new FileInputStream("testfis.txt");
bytesAvailabe = fis.available();//获得该文件可用的字节数
if(bytesAvailabe>0){
content = new byte[bytesAvailabe];//创建可容纳文件大小的数组
fis.read(content);
}
System.out.println(Arrays.toString(content));//打印数组内容
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
if(fis!=null){
try {
fis.close();
}
catch (IOException e) {
e.printStackTrace();
}
}
else{
System.out.println("file dosen't close!!");
}
}
6.2 结合题集6-2代码,要将什么样操作放在finally块?为什么?使用finally关闭资源需要注意一些什么?
答:
- finally是一个一定会执行的内容,无论异常有没有被catch到,最后都会有一个统一的地方来close资源,finally块里应该放的是一些资源的关闭的操作,像题6-2也是把
resource.close();
放在finally里面。 - 使用finally关闭资源的时候应该注意如果前面使用了
System.exit(0)
,finally语句就不会执行了,所以关闭资源时,finally之前不能出现System.exit(0)
。
6.3 使用Java7中的try-with-resources
来改写上述代码实现自动关闭资源。简述这种方法有何好处?
好处:try-with-resources
的作用是自动调用资源的close()函数,它实现资源的自动回收处理,这样子写代码就很便利很高效了。
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));//打印数组内容
} catch (IOException e) {
e.printStackTrace();
}
}
7. 面向对象设计作业-图书馆管理系统(分组完成,每组不超过3个同学)
登录lib.jmu.edu.cn,对图书进行搜索。然后登录图书馆信息系统,查看我的图书馆。如果让你实现一个图书借阅系统,尝试使用面向对象建模。
分组:
黄子颖 201621123045
翁华辉 201621123042
7.1 该系统的使用者有谁?
答:学生以及管理员。
7.2 主要功能模块(不要太多)及每个模块的负责人。下周每个人要提交自己负责的模块代码及运行视频。
学生:
学生注册
学生登录
查看书籍
借阅书籍
归还书籍
管理员:
查看书籍
添加书籍
删除书籍
7.3 该系统的主要的类设计及类图(可用)
7.4 你准备如何存储图书信息、解决信息、读者信息等。
存储图书的信息使用Map键值对,key值放图书,value值放图书的数量数量。
借阅的信息也使用Map键值对存储
读者的信息使用Set集合存储
三.码云及PTA
题目集:异常
3.1. 码云代码提交记录
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
3.2 截图PTA题集完成情况图
需要有两张图(1. 排名图。2.PTA提交列表图)
3.3 统计本周完成的代码量
需要将每周的代码统计情况融合到一张表中。
周次 | 行数 | 新增行数 | 文件数 | 新增文件数 |
---|---|---|---|---|
1 | 115 | 115 | 17 | 17 |
2 | 421 | 306 | 24 | 7 |
3 | 698 | 277 | 30 | 6 |
5 | 1085 | 387 | 38 | 8 |
6 | 1497 | 412 | 48 | 10 |
7 | 2033 | 536 | 57 | 9 |
8 | 2265 | 232 | 60 | 3 |
9 | 2728 | 522 | 65 | 5 |
10 | 3360 | 632 | 73 | 8 |
11 | 3958 | 598 | 83 | 10 |