20145101《Java程序设计》第5周学习总结
教材学习内容总结
第八章 异常处理
-
Java是通过try,catch,throw,throws,finally这5个关键字来实现异常处理的。
Try:try语句用大括号{}指定了一段代码,该段代码可能会抛弃一个或多个例外。
Catch:
catch语句的参数类似于方法的声明,包括一个例外类型和一个例外对象。例外类型必须为Throwable类的子类,它指明了catch语句所处理的例外类型,例外对象则由运行时系统在try所指定的代码块中生成并被捕获,大括号中包含对象的处理,其中可以调用对象的方法。import java.util.*; public class Average2 { public static void main(String[] args){ try{ Scanner scanner = new Scanner(System.in); double sum = 0; int count = 0; int number; while(true){ number = scanner.nextInt(); if(number==0){ break; } sum+=number; count++; } System.out.printf("平均%.2f%n", sum/count); }catch (InputMismatchException ex){ System.out.println("必须输入整数"); } } }
Throws:throws总是出现在一个函数头中,用来标明该成员函数可能抛出的各种异常。 如果你想明确地抛出一个RuntimeException,你必须用throws语句来声明它的类型。
Throw:throw总是出现在函数体中,用来抛出一个异常。程序会在throw语句后立即终止,它后面的语句执行不到,然后在包含它的所有try块中(可能在上层调用函数中)从里向外寻找含有与其匹配的catch子句的try块。
import java.io.FileInputStream; import java.io.FileNotFoundException; import java.util.Scanner; public class FileUtil { public static String readFile(String name)throws FileNotFoundException{ StringBuilder builder = new StringBuilder(); try { Scanner scanner = new Scanner(new FileInputStream(name)); while (scanner.hasNext()) { builder.append(scanner.nextLine()); builder.append(' '); } } catch (FileNotFoundException ex){ ex.printStackTrace(); throw ex; } return builder.toString(); } }
Finally:try所限定的代码中,当抛弃一个例外时,其后的代码不会被执行。通过finally语句可以指定一块代码。无论try所指定的程序块中抛弃或不抛弃例外,也无论catch语句的例外类型是否与所抛弃的例外的类型一致,finally所指定的代码都要被执行,它提供了统一的出口。通常在finally语句中可以进行资源的清除工作。如关闭打开的文件等。
第九章 Collection与Map
-
收集对象的行为,像是新增对象的add()方法、移除对象的remove()方法等,都是定义在java.util.Collection中。既然可以收集对象,也要能逐一取得对象,这就是java.lang.Iterable定义的行为,它定义了iterable()方法返回java.util.Iterator操作对象,可以让你逐一取得收集的对象。Collection接口中有三个子接口,分别是List、Set和Queue。如果希望收集时记录记录每个对象的索引顺序,并可依索引取回对象,可以使用java.util.List接口,如果希望收集的对象不重复,具有集合的行为,可以使用java.util.Set接口,如果希望收集对象时以队列方式,收集的对象假如至尾端,取得对象时从前端,则可以使用java.util.Queue接口,如果希望对Queue的两端进行加入、移除等操作,则可以使用java.util.Deque。
List: 类似数组,具有位置信息,带索引
核心方法:
add(int index, E element):可以将指定的元素插入此列表中的指定位置。
remove(int index):移除此向量中指定位置的元素。
set(int index, E element):用指定元素替换列表中指定位置的元素。
ArrayList:《数据结构》中的线性表
LinkedList:《数据结构》中的链表
Set: 其中的对象不能有重复的
Queue: 队列
核心方法
offer:添加一个元素并返回true,如果队列已满,则返回false
poll:移除并返问队列头部的元素,如果队列为空,则返回null
peek:返回队列头部的元素,如果队列为空,则返回null
Deque: 双向队列
教材学习中的问题和解决过程
代码调试中的问题和解决过程
本周代码托管截图
其他(感悟、思考等,可选)
本周的学校可以让我们处理一些简单的Java编程的错误。通过前几章的学习,我们掌握了大量的基础知识,想要把Java知识充分学透,还是血药不停努力敲代码,在敲代码中学习提高。学习并没有什么途径,不停地为之奋斗,一直坚持下去,相信我们终究能够精通java这门编程语言。学Java不能靠一时的兴趣,而需要我们不停地探索,才能有一定的收获。
学习进度条
代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | 重要成长 | |
---|---|---|---|---|
目标 | 5000行 | 30篇 | 400小时 | |
第一周 | 200/200 | 2/2 | 20/20 | |
第二周 | 200/400 | 1/3 | 18/38 | |
第三周 | 200/600 | 1/4 | 22/60 | |
第四周 | 200/800 | 1/5 | 30/90 | |
第五周 | 200/1000 | 1/6 | 30/120 |