zoukankan      html  css  js  c++  java
  • 201521123088《JAVA程序设计》第5周学习总结

    1. 本周学习总结

    1.1 尝试使用思维导图总结有关多态与接口的知识点。

    2. 书面作业

    阅读:Child压缩包内源代码

    1.1 com.parent包中Child.java文件能否编译通过?哪句会出现错误?试改正该错误。并分析输出结果。

    答:否。
    这个有错:

    因为Parent类中的value是私有类型, 在外部不能访问。将private改为protected就可以了。

    输出结果为:1 2 2 1 1 2 1

    1.2 另外一个包中的OutOfParentPackage.java,能否编译通过?提示什么错误?分析原因。如何更改才能使之正常编译?

    答:否。提示The type Parent is not visible。

    因为Parent类默认访问权限是该包内的可以访问,但是 OutOfParentPackage.java 不在 com.parent包中,所以不能访问。

    这么改能正常编译

    public class Parent{
        piblic int i=1;
        protected int j=2;
        public int geti(){
            return i;
        }
        public void getj(){
            System.out.println(j);
        }
    }

    abstract进阶:阅读GuessGame抽象类的设计与使用源代码

    2.1 Guess改造前代码很简单,而改造后的代码使用了抽象类、抽象方法看起来很复杂,那这样的改造到底有什么好处呢?

    答:改造前的代码只能在控制台进行输入和输出操作,而改造后的代码可以在控制台,对话框以及图形界面等进行输入输出操作。

    2.2 如果想将该游戏改造成图形界面,应该进行一些什么操作?

    答:重写抽象类,使得可以在对话框图形界面等输入。

    2.3 结合该例子,你觉得什么时候应该使用abstract?

    答:abstract修饰方法时,抽象方法只保留方法的功能,而具体的执行,交给继承抽象类的子类,由子类重写此抽象方法,调用时可以以多态方式调用子类覆盖(实现)后的方法

    2.4 重要:在这个例子中,变化的是什么,不变的是什么?尝试结合abstract、继承等概念进行说明。

    答:变化的是代码运行环境,不变的是对输入输出进行抽象类定义。类中如果存在没有任何操作的方法,并且表示为abstract,表示这个类定义不完整,不能用来生成实例,就好比不完整的设计图不能用来生产成品一样。子类如果继承抽象类,可以将子类也定义为抽象类,也可以操作抽象方法。

    Comparable与Comparator

    3.1 描述Comparable接口的用途。为什么某个类实现了Comparable接口就可以直接使用Arrays.sort对其进行排序?

    答:此接口强行对实现它的每个类的对象进行整体排序;在类中实现Comparable接口后,调用Arrays.sort()时,传入的是对象,根据指定比较器产生的顺序对指定对象进行排序

    3.2 有了Comparable接口为什么还需要Comparator接口呢?

    答:Comparable接口和Comparator接口,两个都是用来实现集合中元素的比较、排序的。Comparable是在集合内部定义的方法实现的排序,Comparator是在集合外部实现的排序,Comparable接口是一个对象本身已经支持自比较所需要实现的接口。Comparator是一个另写一个外部类来实现的比较的接口。

    面向接口案例分析:阅读Case-StudentDao.zip案例

    4.1 画出类关系图,描述每个类与接口的作用。

    答:

    4.2 StudenDaoListImpl与StudentDaoArrayImpl有何区别?

    答:StudenDaoListImpl是用ArrayList实现的,数组的大小可以随student的增加而动态改变;而StudentDaoArrayImpl是用数组实现的,数组的大小固定为80,。

    5.什么是面向接口编程?面向接口编程的好处是什么?结合题目3与4中的Test.java的代码讨论分析。不要百度原封不动照搬!

    答:系统的各种功能是由许许多多的不同对象协作完成的,在系统分析和架构中,分清层次和依赖关系,每个层次不是直接向其上层提供服务(即不是直接实例化在上层中),而是通过定义一组接口,仅向上层暴露其接口功能,上层对于下层仅仅是接口依赖,而不依赖具体类。

    结对编程:面向对象设计(大作业2-非常重要)

    内容:使用Java代码完成上周做的面向对象设计大作业,需要有初步界面。实现的功能尽量简单,少而精,只包含必要的功能,不要追求高大全。
    写出:类图(尽量精简,不用太多子类,两个即可)、系统常用功能描述、关键代码与界面
    形式: 两人依托码云合作完成。请在这里贴出你们的学号、姓名与任务分工。
    注意: 再过几次课要讲Java图形界面编程,到时候要将该系统升级为图形界面。系统的业务逻辑部分应该变化不大,变化大的是输入与输出部分。所以编码的时候,输入(Scanner)与输出(System.out)的代码,请不要将其与某个业务处理函数绑死。
    选做加分: 给出两人在码云上同一项目的提交记录截图,额外加分。注:两个人在码云上新建一个项目。
    参考资料:
    结对编程参考资料
    可以使用Processon画图

    3. 码云上代码提交记录及PTA实验总结

    题目集:jmu-Java-04-面向对象2-进阶-多态接口内部类

    3.1. 码云代码提交记录

    在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

    3.2. PTA实验

    继续完成前面未完成的实验面向对象1-基础-封装继承
    函数(选做:4-1)、编程(5-1, 5-2)
    一定要有实验总结

    5-1:题目要求比较name和age进行升序排列,那么重点就在于比较,只要采用实现Comparable接口,然后重写compareTo()方法就可以,之后直接使用Arrays.Sort进行排序即可,因为题目是升序,因此可以使用return this.getage-o.getage;若题目是降序,则需要用其他方法,否则会出错。

    5-2:这题直接用comparator接口来实现,定义两个方法都implements comparator,分别对name和age进行比较排序,因为Comparable接口只能对实现类进行比较,而comparator可以对外部类进行比较,只要覆盖compare()方法就好,最后使用Arrays.Sort进行排序,而本题中使用Arrays.sort(ps,new NameComparator());Arrays.sort(ps,new AgeComparator());进行排序,其中ps是PersomSortable2类型的数组。

  • 相关阅读:
    2014 10 07 ················男人感悟100(转自MOP)
    BFS和DFS优先搜索算法
    求素数算法-网摘
    DP问题各种模型的状态转移方程 (转)
    srand函数
    #include<algorithm>
    常用算法一(分治算法)
    杭电ACM题目分类
    四方定理
    五大常用算法之二:动态规划算法
  • 原文地址:https://www.cnblogs.com/lzy-mini/p/6618310.html
Copyright © 2011-2022 走看看