1. 本周学习总结
1.1 尝试使用思维导图总结有关多态与接口的知识点。
2. 书面作业
代码阅读:Child压缩包内源代码
1.1 com.parent包中Child.java文件能否编译通过?哪句会出现错误?试改正该错误。并分析输出结果。
答:不能通过编译, public void getParenti()出现错误,原因是The field Parent.i is not visible,可以将Parent类中i的属性的修饰符private改为protected,private只能在自己的类中使用,输出结果为1 2 2 1 1 2 1
1.2 另外一个包中的OutOfParentPackage.java,能否编译通过?提示什么错误?分析原因。
答:不能通过编译,错误原因是The type Parent is not visible,因为parent前没有public,所以没有权限调用。
1.3 回答:如果为了访问到protected修饰的属性或方法应该怎么办?
答:protected的访问范围是同一个包或子类,所以要访问到protect修饰的属性或方法要在同一个类中调用它。
abstract进阶:阅读GuessGame抽象类的设计与使用源代码
2.1 Guess改造前代码很简单,而改造后的代码使用了抽象类、抽象方法看起来很复杂,那这样的改造到底有什么好处呢?
答:改造前,未使用抽象类,只能控制台输出;改造后,使用抽象类,可以在控制台,也可以使用对话框图形界面等输入。
2.2 如果想将该游戏改造成图形界面,应该进行一些什么操作?
答:需要一个定义图形界面的类,然后用输入输出语句来重写抽象类当中的抽象方法。
2.3 结合该例子,你觉得什么时候应该使用abstract?
答:使用abstract修饰,是为了创建一个具体方法还不确定的基类。
2.4 重要:在这个例子中,变化的是什么,不变的是什么?尝试结合abstract、继承等概念进行说明。
答:不变的是产生的随机数,改变的是抽象方法的声明,输入输出的方式不同。
Comparable与Comparator
3.1 描述Comparable接口的用途。为什么某个类实现了Comparable接口就可以直接使用Arrays.sort对其进行排序?
答:此接口强行对实现它的每个类的对象进行整体排序。此排序被称为该类的自然排序 ,类的 compareTo 方法被称为它的自然比较方法 。实现此接口的对象列表(和数组)可以通过 Collections.sort (和 Arrays.sort )进行自动排序。实现此接口的对象可以用作有序映射表中的键或有序集合中的元素,无需指定比较器。(以上源于百度)即可通过compareTo方法实现排序。
3.2 有了Comparable接口为什么还需要Comparator接口呢?
答:Comparable接口使用的是自然排序,但这种排序无法满足要求时,就需要用Comparator接口编写一个适用于情况的比较器。
面向接口案例分析
阅读Case-StudentDao.zip案例
4.1 画出类关系图,描述每个类与接口的作用。
StudentDao接口:提供三个方法,分别为writeStudent、readStudent、diplayAllStudent(),用于写入,读取和显示学生信息;
StudenDaoListImpl类:设置一个以Student对象的ArrayList,定义了接口的三个具体方法;
StudentDaoArrayImpl类:使用数组来存放学生信息,具体实现StudentDao接口的三个抽象方法。
4.2 StudenDaoListImpl与StudentDaoArrayImpl有何区别?
答:StudentDaoArrayImpl是用数组来存储学生,StudenDaoListImpl是使用ArrayList来存储学生,两者的数据结构不同。
5.什么是面向接口编程?面向接口编程的好处是什么?
结合题目3与4中的Test.java的代码讨论分析。不要百度原封不动照搬!
答:一个面向对象的系统中,系统的各种功能是由许许多多的不同对象协作完成的。在这种情况下,各个对象内部是如何实现自己的,而各个对象之间的协作关系则成为系统设计的关键。面向接口编程就是指按照这种思想来编程。
比如题目3用到Comparable和Comparator两个接口,我们可以把自己定义的类和原有的类进行比较,从而调用Arrays里面已经写好的sort()方法来排序。
好处在于在修改某个模块时,不需要对其他模块进行改动,大大增强了程序的稳定性。
3. 码云上代码提交记录及PTA实验总结
题目集:jmu-Java-04-面向对象2-进阶-多态接口内部类
3.1. 码云代码提交记录
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
3.2. PTA实验
实验一:主要问题是实现comparable接口。调用Arrays.sort()对name排序,如果name相同再对age进行升序排序。
实验二:这题需要另外的类实现排序,即编写NameComparator类,实现对象的name属性的排序和对象的age属性的排序。