1.本章学习总结
2.书面作业
1.代码阅读:Child压缩包内源代码
1.1 com.parent包中Child.java文件能否编译通过?哪句会出现错误?试改正该错误。并分析输出结果。
不能。System.out.println(i);
出错。可以把i改成protected
的。输出结果:1 2 2 1 1 2 1
1.2 另外一个包中的OutOfParentPackage.java,能否编译通过?提示什么错误?分析原因。
不能。提示错误** the type Parent is not visible,因为Parent前面没有任务修饰符,所以是默认的,可以在Parent之前加public
1.3 回答:如果为了访问到protected修饰的属性或方法应该怎么办?**
在同一个类中,或在同一个包中,或是在子类中调用这些属性与方法
2.abstract进阶:阅读GuessGame抽象类的设计与使用源代码
2.1 Guess改造前代码很简单,而改造后的代码使用了抽象类、抽象方法看起来很复杂,那这样的改造到底有什么好处呢?
改造前,未使用抽象类,只能控制台输出
改造后,使用抽象类,可以在控制台,也可以使用对话框图形界面等输入
2.2 如果想将该游戏改造成图形界面,应该进行一些什么操作?
设计一个图形界面猜数字的类去继承Guess中的抽象类,然后用图形界面支持的输入输出语句来重写抽象类当中的抽象方法。
2.3 结合该例子,你觉得什么时候应该使用abstract?
抽象类用abstract来修饰,包含抽象方法。当某个父类知道子类包含怎样的方法,但不知道这些子类到底应该如何实现这些方法时,可以使用abstract。
2.4 重要:在这个例子中,变化的是什么,不变的是什么?尝试结合abstract、继承等概念进行说明。
变化的是数字,不变的是处理数字的方法。父类GuessGame使用abstract,修饰猜数字的方法,声明(定义)而没有实现,需要子类继承并覆盖父类的方法。
3.Comparable与Comparator
3.1 描述Comparable接口的用途。为什么某个类实现了Comparable接口就可以直接使用Arrays.sort对其进行排序?
强行对实现它的每个类的对象进行整体排序。在这个类中实现Comparable接口后,调用Arrays.sort()时,将排序类对象作为参数传入,根据指定比较器产生的顺序对指定对象进行排序
3.2 有了Comparable接口为什么还需要Comparator接口呢?
当不能使用Comparable接口进行排序的时候,就可以使用Comparator接口实现了。
3.3 可选:使用匿名内部类、Lambda表达式实现PTA编程5-2。
4.面向接口案例分析
阅读Case-StudentDao.zip案例
4.1 画出类关系图,描述每个类与接口的作用。
4.2 StudenDaoListImpl与StudentDaoArrayImpl有何区别?
这两个类具体的方法不同。StudenDaoListImpl是用ArrayList实现的,StudentDaoArrayImpl是用数组来实现的。
5.什么是面向接口编程?面向接口编程的好处是什么?
结合题目3与4中的Test.java的代码讨论分析。不要百度原封不动照搬!
面向接口编程:我们可以把方法的声明与实现分开,在接口中放抽象方法,在类中实现该方法,类实现接口。题目四中Test文件中,实现学生的存储,只需要写好学生的输入,查找和输出即可,还未决定如何实现,也就是StudentDao接口的三个抽象方法,一开始用数组来实现功能,若要改变成ArraysList的存储方式,不需要将main里的函数大浮动改动,只需再写一个类来实现,main由于是调用StudentDao接口的抽象方法,所以不用改动现有代码。好处:当需要做改动的时候,不会引起很大的变动。
6.结对编程:面向对象设计(大作业2-非常重要)
内容:使用Java代码完成上周做的面向对象设计大作业,需要有初步界面。实现的功能尽量简单,少而精,只包含必要的功能,不要追求高大全。
写出:类图(尽量精简,不用太多子类,两个即可)、系统常用功能描述、关键代码与界面
形式: 两人依托码云合作完成。请在这里贴出你们的学号、姓名与任务分工。
注意: 再过几次课要讲Java图形界面编程,到时候要将该系统升级为图形界面。系统的业务逻辑部分应该变化不大,变化大的是输入与输出部分。所以编码的时候,输入(Scanner)与输出(System.out)的代码,请不要将其与某个业务处理函数绑死。
选做加分: 给出两人在码云上同一项目的提交记录截图,额外加分。注:两个人在码云上新建一个项目。
参考资料:
结对编程参考资料
可以使用Processon画图
3.码云截图
4.pta
5.1改写了Comparable,用于对象的名字的排序。
5.2需要不同的方法实现排序.编写NameComparator类,实现对name进行升序排序,编写AgeComparator类,对age进行升序排序。