作业05-继承、多态、抽象类与接口
1. 本周学习总结
1.1 写出你认为本周学习中比较重要的知识点关键词
接口 comparable comparator interface
1.2 尝试使用思维导图将这些关键词组织起来。注:思维导图一般不需要出现过多的字。
1.3 可选:使用常规方法总结其他上课内容。
2. 书面作业
1. 面向对象设计大作业(团队项目,2-3人)
内容:继续完善上次的大作业。
1.1 项目简介表格:
码云
成员 | 负责部分 | 博客地址 |
---|---|---|
陈剑波 | Car,Mart | 博客地址 |
朱汇盈 | Goods,Main | 博客地址 |
刘思远 | User,UserList | 博客地址 |
1.2 系统常用功能框架图
提示:在XMind文本方框中,可通过按Shift+Enter将字竖起来。
1.3 系统总体类图
类图绘制参考资料:
1.4 购物车、商品、系统关键代码截图(主要截取自己负责的部分)
1.5 其他:跟上次的系统比较,系统的设计等有何修改。其他感想。
思路比上次清晰许多,代码不仅比上次更加完善且更为简洁。这次在结构上有大的调整,一些方法调整了一下归属的类。
2. abstract:阅读GuessGame抽象类的设计与使用源代码
2.1 Guess改造前代码很简单,而改造后的代码使用了抽象类、抽象方法,看起来更复杂,这样的改造到底有什么好处呢?
在输入输出使用抽象类,可以在控制台,也可以在其它地方实现。
2.2 GuessGame(改造后).java中有抽象方法与非抽象方法,你觉得抽象类中什么样的方法应该声明为abstract,什么方法不需要声明为abstract直接实现即可。
拥有不同实现的方法、不明确的应该声明为abstract。可以实例化、有明确方法不需要abstract。
2.3 重要:在这个例子中,变化的是什么,不变的是什么?尝试结合abstract等概念进行说明。
变的是输入输出的方法,不变的是游戏的具体实现方法。
3. Comparable与Comparator
3.1 结合PTA 7-1中你的代码说明,为什么某个类实现了Comparable接口,就可以直接使用Arrays.sort对该类型的数组进行排序?
Comparable是对象之间比较排序,只要实现 public int compareTo(T o) 就可以实现其功能
3.2 结合PTA 7-2 中你的代码说明,有了Comparable接口为什么还需要Comparator接口呢?
comparator是对单个元素进行排序,而comparable是对整个对象进行排序。
3.3 以前的作业Shape, Rectangle,Cirlce中,Shape类中什么方法应声明为abstract?说出原因。
求周长getPerimeter()和求面积getArea()可以声明为abstract,他们具体的实现方法是不同的。
3.4 有很多Shape类型对象如Rectangle、Circle。希望使用Arrays.sort对他们进行排序,请写出相应代码。并简述应在哪个类上实现Comparable接口比较好?
getArea()的方法有多种,因此在shape实现。
3.5 以3.4你编写的代码为例,简述面向Comparable接口编程、面向父类编程的好处。(注意:一定要结合自己编写的代码)
排序方便,直接调用无需再写。面向父类编程使得编程更加简便、代码更加简洁。
4. 面向接口案例分析
阅读Case-StudentDao.zip案例
4.1 a.画出类关系图。b.StudentDao接口有什么用?
b.声明 读、写、输出 三种方法,方便后面修改及定义
4.2 StudenDaoListImpl与StudentDaoArrayImpl有何共同之处?有何区别?
StudenDaoListImpl用数组存储,而StudentDaoArrayImpl用Array存储。相同之处在都是对实现的功能相同,且都继承StudentDao接口。
4.3 结合Test.java中的main函数,简述面向接口编程的好处。
在具体操作方法不确定时,让继承她的类去具体实现方法,使程序更为灵活。
5. 什么是面向接口编程?面向接口编程的好处是什么?
结合题目4案例中的Test.java的代码进行分析。不要百度原封不动照搬!
面向接口编程是接口声明方法,具体方法由子类去实现。好处是可以有多种实现的方法,使得程序更加灵活,且源代码更加安全不易查看源代码。
3.码云及PTA
题目集:面向对象2-进阶-多态接口内部类
3.1. 码云代码提交记录
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
3.2 截图PTA题集完成情况图
需要有两张图(1. 排名图。2.PTA提交列表图)
3.3 统计本周完成的代码量
第二个路径(U盘)没法统计
将所有代码放在同一文件夹后
需要将每周的代码统计情况融合到一张表中。
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
1 | 0 | 0 | 0 | 0 |
2 | 0 | 0 | 0 | 0 |
3 | 472 | 472 | 11 | 11 |
4 | 472 | 0 | 11 | 0 |
5 | 468 | -4 | 12 | 1 |
6 | 1043 | 575 | 30 | 18 |