神离

博客园 首页 联系 订阅 管理

1. 本周学习总结

1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容。

2. 书面作业

本次PTA作业题集异常

1. 常用异常

结合题集题目7-1回答

1.1 自己以前编写的代码中经常出现什么异常、需要捕获吗(为什么)?应如何避免?

数组越界异常,空指针异常,返回值不匹配异常,这些都是uncheck异常
不需要捕获
使用try-catch语句捕获,最好在敲代码的时候注意逻辑,避免这些错误。

1.2 什么样的异常要求用户一定要使用捕获处理?

除了error和RuntimeException其他都需要捕获处理

2. 处理异常使你的程序更加健壮

题集题目7-2

2.1 实验总结。并回答:怎么样才能让你的程序更加健壮?

在进行字符串转换为数字时加入'try-catch'语句来处理异常,
需要注意出现异常后下标需要减1。

对程序进行异常处理可以有效的提高程序的健壮性,当我们加上异常处理后,
程序就可以正常运行并告知我们错误信息。但是
我们要忽略掉一些可以忽略的异常,因为过多的异常处理在程序运行的时候还有可能会影响到程序
的性能。

3. throw与throws

题集题目7-3
阅读Integer.parsetInt源代码

3.1 Integer.parsetInt一开始就有大量的抛出异常的代码,这种做法有什么好处?

一旦出错就能很快找出出错类型,不需要一种一种情况的排查
避免传入错误的参数而导致程序崩溃的情况,让程序更加健壮。

3.2 结合自己编写的程序与3.1,分析自己编写的方法抛出异常时一般需要传递给调用者一些什么信息?

4. 用异常改进ArrayIntegerStack

题集题目6-3

4.1 结合6-3代码,回答使用抛出异常的方式代表程序运行时出错有什么好处?比单纯的返回错误值,有何优点?

抛出异常能够精确的知道自己代码出错的位置,在catch语句中也能知道具体出错的类型,
知道更多的出错信息。
把出错信息封装到异常类里面,这样当出错的时候,就可以根据捕获的异常对象获取更多的出错信息。
当编译通过但是运行出现问题时这样try-catch就会非常好用

4.2 如果一个方法内部的内码抛出的是RuntimeException类型的异常,那么方法声明是否应该使用throws关键字,如果使用throws关键字声明该方法抛出的异常,能给我们带来什么好处吗?

RuntimeException类型的异常属于Unchecked Exception,可以不使用throws关键字,用throws关键字抛出异常优点:
当一个异常不想在方法中用try-catch进行处理时,可以将异常抛给别的类或方法来处理,此时就用到了throws。并且throw和throws就该是成对出现的

5. 函数题-多种异常的捕获

题集题目6-1

5.1 结合6-1代码,回答:一个try块中如果可能抛出多种异常,且异常之间可能有继承关系,捕获时需要注意些什么?

如果try中多种异常有继承关系,那么子类的catch语句需要放在父类catch语句前,如果不这么做,程序会先捕获到子类的错误
导致之后本应catch到子类的语句无法执行,当然,这种情况是无法通过编译的

5.2 一个try块中如果可能抛出多种异常,使用Java8的多重异常捕获语法需要注意些什么?

try语句在之后需要多个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;
try{
    FileInputStream fis = new FileInputStream("testfis.txt");
    int bytesAvailabe = fis.available();//获得该文件可用的字节数
    if(bytesAvailabe>0){
        content = new byte[bytesAvailabe];//创建数组
        fis.read(content);//内容读入
    }
}catch(FileNotFoundException | SizeDetermineFailed | MemoryAllocateFailed | ReadFailed e){
    e.getStackTrace();
}finally{
    if (fis != null) {
        try {                     
            fis.close();
        } catch (IOException e) {
            e.printStackTrace();
            System.out.println("找不到文件,请重新输入文件名");
        }catch(Exception e){
            System.out.println("打开或读取文件失败!");
        }
     }
}
System.out.println(Arrays.toString(content));//打印数组内容
System.out.println(Arrays.toString(content));

6.2 结合题集6-2代码,要将什么样操作放在finally块?为什么?使用finally关闭资源需要注意一些什么?

close()释放资源方法放到了finally块中。
因为finally起到维护对象的内部状态,并可以清理非内存资源的作用。

注意:在关闭资源的时候也会遇到异常,这时候也要捕获。

6.3 使用Java7中的try-with-resources来改写上述代码实现自动关闭资源。简述这种方法有何好处?

byte[] content = null;
try(FileInputStream fis = new FileInputStream("testfis.txt")){
    int bytesAvailabe = fis.available();//获得该文件可用的字节数
    if(bytesAvailabe>0){
        content = new byte[bytesAvailabe];//创建数组
        fis.read(content);//内容读入数组
    }
}catch(Exception e){
    e.printStackTrace();
}

System.out.println(Arrays.toString(content));

好处:try-with-resource语句确保资源被关闭,相比之前在finally块来实现资源关闭较为方便,也简化了代码。

7. 面向对象设计作业-图书馆管理系统(分组完成,每组不超过3个同学)

登录lib.jmu.edu.cn,对图书进行搜索。然后登录图书馆信息系统,查看我的图书馆。如果让你实现一个图书借阅系统,尝试使用面向对象建模。

7.1 该系统的使用者有谁?

学生与图书管理员

7.2 主要功能模块(不要太多)及每个模块的负责人。下周每个人要提交自己负责的模块代码及运行视频。

学生(张雨阳)
登录,查看,借阅,归还

图书管理员(李铎)
查看图书,添加图书

7.3 该系统的主要的类设计及类图

7.4 你准备如何存储图书信息、解决信息、读者信息等。

存储图书信息使用Map键值对,key值存放图书,value值存放数量。
读者信息使用集合存储

3.码云及PTA

题目集:异常

3.1. 码云代码提交记录

3.2 截图PTA题集完成情况图

需要有两张图(1. 排名图。2.PTA提交列表图)

3.3 统计本周完成的代码量

需要将每周的代码统计情况融合到一张表中。

周次 总代码量 新增代码量 总文件数 新增文件数
1 73 73 2 2
2 281 281 9 9
3 908 908 16 16
4 1122 214 16 16
5 1557 435 32 11
6 2056 499 45 13
7 2145 89 48 3
8 2446 301 54 6
9 2879 433 64 10
10 3355 486 78 14
posted on 2017-11-25 19:31  神离  阅读(146)  评论(2)    收藏  举报