20155315 2016-2017-2 《Java程序设计》第五周学习总结
教材学习内容总结
第8章 异常处理
1.使用try...catch
- 与C语言中程序流程和错误处理混在一起不同,Java中把正常流程放try块中,错误(异常)处理放catch块中。
- 如果父类异常对象在子类异常前被捕捉,则catch子类异常对象的区块将永远不会被执行。
- catch括号中列出的异常不得有继承关系,否则会发生编译错误。
- 在catch区块进行完部分错误处理之后,可以使用throw将异常再抛出。
2.异常继承架构
Error对象抛出时,基本不用处理,最多留下日志信息;- 程序设计本身的错误,使用
Exception或其子类实例来实现,所以错误处理通常称为异常处理。
- Java异常处理是要处理
Exception类及其子类(Checked Exception)RuntimeException及其子类也不用处理(Unchecked Exception)。- 产生
RuntimeException的问题在调用代码。
但就语法与继承架构上来说,如果某个方法声明会抛出Throwable或子类实例,只要不属于Error,java.lang.RuntimeException或其子类异常,在设计程序是要明确使用try、catch语法加以处理,或用throws声明这个方法会抛出异常,否则就会编译失败。
3.catch 和 throw
书上通过生动的例子总结了catch和throw的区别。总的来说,catch捕捉的异常由当前环境信息进行处理,而throw抛出的异常由调用方法的客户端进行处理。后者在编译上更为灵活。
4.堆栈追踪
- 要得知异常发生的根源,以及多重方法调用下异常的堆栈传播,会自动收集异常对象。
- 一般来说,最上层是产生异常的根本原因,找代码问题可以从最下层开始找。
- 要善用堆栈追踪,程序不要有私吞异常的行为,也不要对异常做不恰当的处理。
- 使用throw重抛异常的时候,异常的追踪堆栈起点在异常发生的根源,而不是抛出的地方。
5.assert断言
- 断言指的是程序执行的某个时间点或某个情况下,必然处于或不处于某种状态。
- 断言的结果一定是成立或不成立。
- 运行java程序时,默认不启动断言检查;若要启动断言检查,要使用java -ea。
- 何时该使用断言:
- 断言客户端调用方法之前,已经准备要某些前置条件(通常在private方法之中)
- 断言客户端调用方法后,具有方法承诺的结果
- 断言对象某个时间点下的状态
- 使用断言取代批注
- 断言程序流程中绝对不会执行到的程序代码部分。
6.finally
- 如果想一定要执行关闭资源的动作,try、catch语法可以搭配finally使用,这样,无论是否有异常,finally区块一定会被执行。
- 如果撰写的流程中有return也有finally区块,那么finally区块会先执行再将值返回。
7.关闭资源
- 用
try with resources关闭多个资源时用分号分隔。 try with resources的对象必须实现AutoCloseable接口。
第九章 Collection与Map
1.Collection架构
- 可以收集对象,也能逐一取得对象,这是
java.lang.Iterable定义的行为。 - List是一种Collection,作用是收集对象,并以索引方式保留收集的对象顺序。
2.ArrayList和LinkedList
- ArrayList使用的是数组的特性,数组在内存中回事连续的线性空间,就相当于是数据结构中学到的线性表;
- LinkedList在操作List接口时,采用了链接结构,就相当于是数据结构中的链表,想要指定索引随机存取对象时,链接方式都得使用从第一个元素开始查找下一个元素的方式。
- 若收集的对象经常有变动索引的情况,用LinkedList比较好。
3.Queue
- Queue定义了自己的offer()、poll()与peek()等方法,操作失败时会返回特定的值。
- Deque(双向队列)时Queue的子接口,它与Queue有几个操作是等义的。
- 可以用
ArrayQueue实现堆栈。
4.泛型
- 用角括号告知编译程序对象收集的类型。
- Java的CollectionAPI都支持泛型语法。
5.Lambda表达式
- 遵循"DRY"(Don't Repeat Yourself)原则,省略了接口类型与方法名称,简化编程过程。
- 如果是单参数又无须写出参数类型的时候,()也可以省略。
- 在Lambda表达式中使用区块是,如果方法必须返回值,在区块中必须使用return。
6.Interable与Iterator
- JDK5出现前,Iterator()方法是定义在Collection接口中的;JKD5出现后,Iterator()方法提升在新的
java.util.Iterable父接口,可以使用foreach()方法显示收集的所有对象。 - List是一种Iterable,可以使用forEach()方法。
- 任何操作Iterable的对象,都可以使用这个forEach()方法,而不一定要是Collection。
7.Comparable与Comparator
- Collections的sort()方法要求被排序的对象,必须操作
java.lang.Comparable接口,这个接口有个compareTo()方法必须返回大于0、等于0或小于0的数。 - Collections的sort()方法有另一个重载版本,可接受
java.lang.Comparator接口的操作对象,排序方式将根据Comparator的compare()定义来决定。 - sort:Java中对象排序,要么对象实现了Comparable可以直接sort,要么提供Comparator对象告知sort如何排序。也就是说,若对象本身就是Comparable,即可比较的,就可以直接排序;若不是,就另行指定Comparator对象告诉程序依照某种规律进行排序。
8.Map
- Dictionary与HashTable不建议使用
(1)HashMap
- put:建立键值对应,第一个自变量,第二个自变量是值
- get:指定键取回对应的值。
(2)TreeMap
使用TreeMap建立键值对应,键的部分将会排序,条件是作为键的对象必须操作Comparable接口,或者创建TreeMap时指定操作Comparator接口的对象。
(3)Properties
- setProperty():指定字符串类型的键值;
- getProperty():指定字符串类型的键;
- load():指定InputStream的实例。
(4)访问Map键值
- keySet():返回set对象
- values():取得Map中所有的值
- entrySet():同时取得Map的键与值
- getKey():取得键
- getValue():取得值
教材学习中的问题和解决过程
- 问题1: API文档中带throws的必须使用try...catch
- 解决1: 查看API文件,read()方法声明中会抛出
IOException,IOException是Exception的直接子类,但不属于RuntimeException或其子类,这是受检异常,在设计程序是要明确使用try、catch语法加以处理,或用throws声明这个方法会抛出异常,否则就会编译失败。 - 问题2: 用throws和用throw有什么区别?
- 解决2:
- throws:无法自行处理,用于声明方法会抛出异常
- throw:方法中抛出
Checked Exception,方法声明中必须有throws
用户程序自定义的异常和应用程序特定的异常,必须借助于throws和throw语句来定义抛出异常。
- throw是语句抛出一个异常,语法:throw(异常对象);throw e;
- throws是方法可能抛出异常的声明。(用在声明方法时,表示该方法可能要抛出异常)语法:(修饰符)(方法名)([参数列表])[throws(异常类)]{......}
public void doA(int a) throws Exception1,Exception3{......}
问题3: 什么是多重捕捉,要注意什么问题?
解决3: 一开始看书时,觉得多重捕捉就是讲多个异常合在一起捕捉,遵循"DRY"(Don't Repeat Yourself)原则,使程序更简洁。但是多重捕捉时出现问题,发现是没有注意异常继承架构。在多重捕捉的时候,catch括号中列出的异常不得有继承关系,否则会发生编译错误。
问题4:
printStackTrace和fillInStackTrace的区别解决4: 使用
printStackTrace()方法时,异常的追踪堆栈起点在异常发生的根源,而不是抛出的地方;使用fillInStackTrace()方法时,堆栈追踪从重抛处开始追踪。问题5: 如何区分继承与泛型?
解决5: 泛型无法提供像继承中的动态绑定功能。
泛型主要是针对程序设计时的函数而言,继承主要是面向对象时更便于操作和修改。
代码调试中的问题和解决过程
- 编译p269的Students.java时遇到如下问题

解决:查看代码发现,最后输出的应该是student而不是set。 - 修改代码后再次编译后发现

解决:原因是jdk1.5里的集合类的创建和jdk1.4里有些区别,主要是jdk1.5里增加了泛型,也就是说可以对集合里的数据进行检查。通过后面对泛型的学习,再次修改了代码。 - 第三次编译发现

查找资料后,还未得到解决。之后学习中有想法了或者能力足够解决再更新解决情况。
代码托管
- 用statistics脚本查看代码行数

- 代码提交结果

上周考试错题总结
4.填空:”Hello”.charAt(1) 的值是(++‘e’++)
理解情况:charAt()方法返回指定索引位置的char值。索引范围为0~length()-1.本道题中索引的为"1",也就是第二位"e"。5.填空:System.out.println( “HELLO”.( ++toLowerCase()++ ) ) 会输出“hello”.
理解情况:toLowerCase的意思是将所有的英文字符转换为小写字母;toUpperCase的意思是将所有的英文字符转换为大写字母。本题中,要求将所有的大写字母转换为小写字母输出6.填空:”Hello”.substring(++0,2++ )的值是“He”
理解情况:substring() 方法用于提取字符串中介于两个指定下标之间的字符。本题要求输出"He",则两个指定下标应是0,223.CH06填空:实现一个类中的equals()方法时,一定要同时实现(++hashCode()++)方法
理解情况:虽然书上说要之后才会学到,但我查找资料发现同时实现两种方法是为了保证对象的唯一性。30.CH07 填空:面向对象中,设计经验可以用(++设计模式++)表达
理解情况:知道了设计经验可以用设计模式来表达,其实就是一种模板,供交流学习。
结对及互评
评分标准(满分10分)
从0分加到10分为止
正确使用Markdown语法(加1分):
- 不使用Markdown不加分
- 有语法错误的不加分(链接打不开,表格不对,列表不正确...)
- 排版混乱的不加分
模板中的要素齐全(加1分)
- 缺少“教材学习中的问题和解决过程”的不加分
- 缺少“代码调试中的问题和解决过程”的不加分
- 代码托管不能打开的不加分
- 缺少“结对及互评”的不能打开的不加分
- 缺少“上周考试错题总结”的不能加分
- 缺少“进度条”的不能加分
- 缺少“参考资料”的不能加分
教材学习中的问题和解决过程, 一个问题加1分
代码调试中的问题和解决过程, 一个问题加1分
本周有效代码超过300分行的(加2分)
- 一周提交次数少于20次的不加分
其他加分:
- 周五前发博客的加1分
- 感想,体会不假大空的加1分
- 排版精美的加一分
- 进度条中记录学习时间与改进情况的加1分
- 有动手写新代码的加1分
- 课后选择题有验证的加1分
- 代码Commit Message规范的加1分
- 错题学习深入的加1分
扣分:
- 有抄袭的扣至0分
- 代码作弊的扣至0分
点评模板:
基于评分标准,我给本博客打分:XX分。得分情况如下:xxx
点评过的同学博客和代码
收获
本周老师让我们开始结对学习,这在一定程度上方便了同学之间的互相学习和促进。这周虽然博客写完了,但对章节内容只能说是一知半解,有时候遇到的问题还不足以解决。在之后的学习中,我还会多看看以前写过的代码,希望随着知识的积累能让我解决以前没解决的问题。
学习进度条
| 代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | 重要成长 | |
|---|---|---|---|---|
| 目标 | 5000行 | 30篇 | 400小时 | |
| 第一周 | 20/20 | 1/1 | 10/10 | 安装了JDK、IDEA和Git,写了第一个Java程序 |
| 第二周 | 97/117 | 2/3 | 20/30 | 用Linux上传代码,熟悉修改文件的命令行 |
| 第三周 | 336/453 | 2/4 | 35/65 | 在Linux上安装JDK和IDEA,更熟悉vi的操作指令以及修改时需要注意的地方。 |
| 第四周 | 851/1304 | 1/5 | 25/90 | 学习用JDB调试程序 |
| 第五周 | 834/2138 | 1/7 | 32/122 | 能自己设计简单的程序,遇到问题也基本上能通过前面的学习和查资料解决,还有问题没有得到解决。 |
- 计划学习时间:35小时
- 实际学习时间:32小时
参考资料
20155315 2016-2017-2 《Java程序设计》第五周学习总结的更多相关文章
- 201521123025<java程序设计>第五周学习总结
1. 本周学习总结 2. 书面作业 1.代码阅读:Child压缩包内源代码 1.1 com.parent包中Child.java文件能否编译通过?哪句会出现错误?试改正该错误.并分析输出结果. 1.2 ...
- Java程序设计第五周学习总结
1. 本周学习总结 1.1 尝试使用思维导图总结有关多态与接口的知识点. 1.2 可选:使用常规方法总结其他上课内容. 2. 书面作业 **代码阅读:Child压缩包内源代码 Child.java源代 ...
- 20155336 2016-2017-2《JAVA程序设计》第九周学习总结
20155336 2016-2017-2<JAVA程序设计>第九周学习总结 教材学习内容总结 第十六章 JDBC(Java DataBase Connectivity)即java数据库连接 ...
- 20145213《Java程序设计》第九周学习总结
20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...
- 21045308刘昊阳 《Java程序设计》第九周学习总结
21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...
- 20145236 《Java程序设计》第九周学习总结
20145236 <Java程序设计>第九周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC简介 1.JDBC是java联机数据库的标准规范.它定义了一组标准类与接口,标准API ...
- 20155304田宜楠2006-2007-2 《Java程序设计》第一周学习总结
20155304田宜楠2006-2007-2 <Java程序设计>第一周学习总结 教材学习内容总结 - 浏览教材,根据自己的理解每章提出一个问题 第一章 除了书上提到的开发工具还有什么适合 ...
- 20155303 2016-2017-2 《Java程序设计》第二周学习总结
20155303 2016-2017-2 <Java程序设计>第二周学习总结 教材学习内容总结 『注意』 "//"为单行批注符: "/*"与&quo ...
- 20145237 《Java程序设计》第九周学习总结
20145237 <Java程序设计>第九周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令 ...
- 20175209 《Java程序设计》第九周学习总结
20175209 <Java程序设计>第九周学习总结 一.教材知识点总结 有关数据库下载中存在可能出现的问题已经在博客<数据库安装和使用过程中出现的一些问题>给出了相应的解决办 ...
随机推荐
- 第五周PSP&进度条
团队项目psp: 一.表格 C类型 C内容 S开始时间 E结束时间 I时间间隔 T净时间(mins) 预计花费时间(mins) 讨论 讨论用户界面 9:27 10:42 18 57 60 分析 ...
- testNg-build.xml
<?xml version="1.0" encoding="UTF-8" standalone="no"?> <proje ...
- [转帖]go 的goroutine 以及 channel 的简介.
进程,线程的概念在操作系统的书上已经有详细的介绍.进程是内存资源管理和cpu调度的执行单元.为了有效利用多核处理器的优势,将进程进一步细分,允许一个进程里存在多个线程,这多个线程还是共享同一片内存空间 ...
- 笔记:delphi 与 Query
以下不保存证正确 Query用SQL语言执行过的,没有必要Cancel.Post,因为其会对数据库直接操作:执行Update.Insert.Delete请用SQL语句: 用Table使用对当前记录直接 ...
- vue自动路由-单页面项目(非build时构建)
博客中自动路由的原理? 答:简单点说,就是在请求页面时,根据url进行动态添加路由. 与其它自动路由博客的区别? 目前网上的博客,一般都是在build的时候进行动态路由添加,而本博客,采用的是在获得u ...
- P3165 [CQOI2014]排序机械臂
题目描述 为了把工厂中高低不等的物品按从低到高排好序,工程师发明了一种排序机械臂.它遵循一个简单的排序规则,第一次操作找到高度最低的物品的位置 P1P_1P1 ,并把左起第一个物品至 P1P_1P1 ...
- 转:机器学习中的算法(2)-支持向量机(SVM)基础
机器学习中的算法(2)-支持向量机(SVM)基础 转:http://www.cnblogs.com/LeftNotEasy/archive/2011/05/02/basic-of-svm.html 版 ...
- 【刷题】BZOJ 3144 [Hnoi2013]切糕
Description Input 第一行是三个正整数P,Q,R,表示切糕的长P. 宽Q.高R.第二行有一个非负整数D,表示光滑性要求.接下来是R个P行Q列的矩阵,第z个 矩阵的第x行第y列是v(x, ...
- 【刷题】BZOJ 1977 [BeiJing2010组队]次小生成树 Tree
Description 小 C 最近学了很多最小生成树的算法,Prim 算法.Kurskal 算法.消圈算法等等. 正当小 C 洋洋得意之时,小 P 又来泼小 C 冷水了.小 P 说,让小 C 求出一 ...
- 关于Swift中的泛函数find的问题
对于一个数组Array,我们往往需要判断其是否包含某个子项,又或者要查找某个子项是否在这个数组中. 假设有这样一个包含坐标的数组 var pointArray:[CGPoint] = [CGPoint ...