• 201521123031《java程序设计》第五周学习总结


    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属性的排序。

  • 相关阅读:
    实例讲解虚拟机3种网络模式(桥接、nat、Host-only)
    期刊搜索问题——SCI、EI、IEEE和中文期刊
    面向对象分析与设计(C++)课堂笔记
    windows与VMware ubuntu虚拟机实现文件共享
    GDI+在绘制验证码中的使用
    【转】.net中快捷键的使用
    MD5加密“破解”在.NET平台实现最基本的理解
    UE4 Persona 骨架网格物体动画
    从零开始做3D地图编辑器 基于QT与OGRE
    TBB(Intel Threading Building Blocks)学习笔记
  • 原文地址:https://www.cnblogs.com/ltykm/p/6617912.html
Copyright © 2020-2023  润新知