201621123008 《Java程序设计》第十周学习总结

1. 本周学习总结

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

2. 书面作业

本次PTA作业题集异常

1. 常用异常

结合题集题目7-1回答

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

一般出现NullPointException,ArrayIndexOutOfBoundsException,ClassCastException之类的RuntimException这些异常往往是由于程序编写者的大意造成的逻辑错误,属于uncheckException。编写程序时理清之间的逻辑关系,即可。

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

排除逻辑上错误,一些我们无法预料的问题,诸如文件是不是还存在,硬盘是否有损坏,这些情况我们不知道在程序执行期间会不会发生,保险起见我们必须对这些可能发生的异常进行捕获,即所有checkException

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

题集题目7-2

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

总结:使用try网住可能出现的NumberFormatException若无异常则将输入数据填入数组,若出现异常则执行catch块内容,输出异常信息,循环控制值减一。关闭扫描器,打印数组内容。

提高程序健壮性的通用方法:

  • 尽量避免一些逻辑上的错误。

  • 对于无法预知情况出现的异常,进行捕获处理。

  • 对于Error那就没办法了

3. throw与throws

题集题目7-3

阅读Integer.parsetInt源代码

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

查看源代码之后发现在parsetInt()方法的声明体中抛出了NumberFormatException,在方法声明体中抛出异常,就是把在方法中抛出的异常duck掉,让方法的调用者去处理产生的异常。相较于直接在方法体中处理产生的异常对象,把异常duck掉交给方法调用者去处理的好处就是有了充足的信息让方法调用者依据调用的环境信息去处理。

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

PTA7-3中编写的findMax方法为例,需要对beginend的值进行判断,若输入的不合法就给与相应的错误提示信息创建相应的异常对象,将异常对象抛出,当调用者调用该方法时若产生异常就可以根据错误提示信息找到相应的解决办法。

4. 用异常改进ArrayIntegerStack

题集题目6-3

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

在没有学异常处理时我们处理处理错误的方法一般是:列出我们能想到的所有可能发生的异常,但异常的情况总比我们考虑的情况多,难免有没考虑的情况存在。这也使得错误处理代码和业务实现代码混杂,影响程序的可读性,增加维护难度。

学了异常处理机制之后:

  • 将错误集中处理,抓住“漏网之鱼”。

  • 实现业务代码与错误处理代码分离,增强可读性,减小维护难度。

单纯的返回错误值,可能出现将本来产生的结果当作错误信息来处理,使程序变得混乱,使用异机制处理的好处如上。

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

如果是RuntimeException可不用throws关键字声明该方法抛出异常,好处就是有了充足的信息让方法调用者依据调用的环境信息去处理。3.1有说明,此处就不赘述啦。

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

题集题目6-1

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

try块中产生异常,是按顺序执行catch块的,故catch子类异常区块上放,catch父类异常区块下放。若catch父类异常区块放在上边,则catch子类异常区块将永远也不会被执行,我们将无法对症下药,况且编译器也不允许这么做。

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

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。如果关闭文件失败,提示关闭文件失败!`

改过之后的源代码:

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.*;

public class Main {
	public static void main(String[] args) {

		Scanner sc = new Scanner(System.in);
		byte[] content = null;
		FileInputStream fis = null;
		int bytesAvailabe = 0;

		while (true) {
			String path = sc.nextLine();
			try {
				fis = new FileInputStream(path);
				bytesAvailabe = fis.available();// 获得该文件可用的字节数
				if (bytesAvailabe > 0) {
					content = new byte[bytesAvailabe];// 创建可容纳文件大小的数组
					fis.read(content);// 将文件内容读入数组
					System.out.println(Arrays.toString(content));
					break;
				}
			} catch (FileNotFoundException e) {
				System.out.println("找不到文件" + path + ",请重新输入文件名");
				continue;
			} catch (IOException e) {
				System.out.println("打开或读取文件失败!");
				System.out.println(e);
			} finally {
				if (fis != null) {
					try {
						System.out.println("关闭文件ing");
						fis.close();
						System.out.println("关闭文件成功");
					} catch (Exception e) {
						System.out.println("关闭文件失败!");

					}
				}
			}
		}

	}

运行结果:

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

一般将资源的关闭,清理操作放入finall块中,程序执行完毕都要进行资源的关闭或清理。无论异常是否产生finally块中的内容都是必须要执行的。

有时finally块中的语句可能也会产生异常,此时不要忘记捕捉。

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

改写之后的源代码:

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.*;

public class Main {
	public static void main(String[] args) {

		Scanner sc = new Scanner(System.in);
		byte[] content = null;
		int bytesAvailabe = 0;

		while (true) {
			String path = sc.nextLine();
			try (FileInputStream fis = new FileInputStream(path)) {
				bytesAvailabe = fis.available();// 获得该文件可用的字节数
				if (bytesAvailabe > 0) {
					content = new byte[bytesAvailabe];// 创建可容纳文件大小的数组
					fis.read(content);// 将文件内容读入数组
					System.out.println(Arrays.toString(content));
					break;
				}
			} catch (FileNotFoundException e) {
				System.out.println("找不到文件" + path + ",请重新输入文件名");
				continue;
			} catch (IOException e) {
				System.out.println("打开或读取文件失败!");
				System.out.println(e);
			}
		}

	}

}

运行结果:

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

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

7.1 该系统的使用者有谁?

  • 教职工
  • 学生
  • 管理员

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

组员 负责模块
周文华 搜索,借书,还书
林文秀 登录,注册
肖文婷 新书上架,旧书下架

7.3 该系统的主要的类设计及类图(可用)

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

先将所用以注册的用户使用Set保存,再将Set中的对象序列化。

8. 选做:使用异常改进你的购物车系统

举1个例子说明你是如何使用异常处理机制让你的程序变得更健壮。
说明要包含2个部分:1. 问题说明(哪里会碰到异常)。2.解决方案(关键代码)

问题:当输入修改的数量时可能输入字符串

解决代码:

 String content = countJTextField.getText();
        try {
            int count = Integer.parseInt(content);
        } catch (java.lang.NumberFormatException ex) {
            JOptionPane.showMessageDialog(null, "数量为整数");
        }
    }               

9. 选做:使用静态代码扫描工具 扫描自己的购物车代码

8.1 分析自己代码中在规范方面出现的问题。

错误一大堆.......

8.2 思考如何解决这些问题。

只能平时编码的时候多注意,养成正确的编码习惯。

3.码云及PTA

题目集:异常

3.1. 码云代码提交记录

  • 在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

3.2 截图PTA题集完成情况图

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



3.3 统计本周完成的代码量

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

周次 总代码量 新增文件代码量 总文件数 新增文件数
1 665 20 20 20
2 1705 23 23 23
3 1834 30 30 30
4 1073 1073 17 17
5 1073 1073 17 17
6 2207 1134 44 27
7 3292 1085 59 15
8 3505 213 62 3
9 8043 1246 153 16
10 8606 543 167 14
11 9203 597 191 24

选做:4. 拓展

课外练习

JavaTutorial中Questions and Exercises
练习总结

总结:

  • try要和catch一起使用

  • catch父类异常块要下放上放,catch子类类异常块要上放。

  • 在打开关闭文件时,由于我们无法知道该文件是否存在,故而要用try-catch进行捕捉。

原文地址:https://www.cnblogs.com/Dzwh/p/7896137.html