Week06-继承、多态、抽象类与接口

1. 本周学习总结

1.1 写出你认为本周学习中比较重要的知识点关键词

关键字:接口,Comparable,interface关键字,Comparator,继承和多态。

1.2 尝试使用思维导图将这些关键词组织起来。注:思维导图一般不需要出现过多的字。

2. 书面作业

1. 面向对象设计大作业(团队项目,2-3人)内容:继续完善上次的大作业。注意: 再过几次课要讲Java图形界面编程,到时候要将该系统升级为图形界面。系统的业务逻辑部分应该变化不大,变化较大的地方的是输入与输出部分。编码的时候,请不要将处理输入(System.in)与输出(System.out)的代码与某个业务处理方法绑死。

1.1 项目简介表格:

成员 负责部分 博客地址
陈剑波 Car,Mart 博客地址
朱汇盈 Goods,Main 博客地址
刘思远 User,UserList 博客地址

1.2 系统常用功能框架图

1.3 系统总体类图

1.4 购物车、商品、系统关键代码截图(主要截取自己负责的部分)


1.5 其他:跟上次的系统比较,系统的设计等有何修改。其他感想。

上次购物车类中定义了Name,Allprice等,这些是多余的,这周把购物车类改成直接展示物品名称和价格等(虽然这部分不是我负责)。

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

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

改造前的代码只能在控制台运行,使用抽象类改造后,该代码就能在其他界面运行,实用性更高。

2.2 GuessGame(改造后).java中有抽象方法与非抽象方法,你觉得抽象类中什么样的方法应该声明为abstract,什么方法不需要声明为abstract直接实现即可。

抽象类中可变化的声明为abstract,例如本题中的输入输出数字,这段代码需要在不同的环境下运行;而随机生成一个数则可以直接实现,因为这个过程在不同条件下的运行过程是一样的。

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

变化的是输入和输出;不变的是游戏的执行过程。将输入输出声明为abstract类就能使游戏在多种条件下运行,实现多种功能。

3. ComparableComparator

3.1 结合PTA7-1中你的代码说明,为什么某个类实现了Comparable接口,就可以直接使用Arrays.sort对该类型的数组进行排序?

某类实现了Comparable接口后,就重写了compareTo()方法,Arrays.sort就会根据compareTo()方法对该类型的数组进行排序。

3.2 结合PTA7-2中你的代码说明,有了Comparable接口为什么还需要Comparator接口呢?

Comparable是排序接口(类内部比较器),Comparator是类外部比较器;Comparator可以在类外通过定义compareTo()方法进行排序。

3.3 以前的作业Shape,Rectangle,Cirlce中,Shape类中什么方法应声明为abstract?说出原因。

Shape中计算周长和面积的方法应声明为abstract;虽然计算周长面积有具体的过程,但不同的图形有本身的计算法则,所以要定义为抽象。

3.4 有很多Shape类型对象如Rectangle、Circle。希望使用Arrays.sort对他们进行排序,请写出相应代码。并简述应在哪个类上实现Comparable接口比较好?


在抽象父类实现Comparable接口比较好,这样可以使不同形状的图形全都按面积或排序。

3.5 以3.4你编写的代码为例,简述面向Comparable接口编程、面向父类编程的好处。(注意:一定要结合自己编写的代码)

面向父类编程给所有子类一个统一使用方式,在子类中可以省去大量代码,以3.4为例,在各个不同形状子类中就不用进行面积周长排序,只需定义Comparable接口,重写compareTo()方法。同时,如遇到错误,使用该方法只需更改父类中的代码,不用一一更改子类中的错误。

4. 面向接口案例分析

4.1 a.画出类关系图。 b.StudentDao接口有什么用?


StudentDao接口含有录入学生信息,读取学生信息,展示学生信息三种方法;并且与StudenDaoListImplStudentDaoArrayImpl接口,便于修改。

4.2StudenDaoListImplStudentDaoArrayImpl有何共同之处?有何区别?

  • StudenDaoListImplStudentDaoArrayImpl都用于修改学生信息,都与StudentDao接口;
  • 二者区别在于储存学生信息的方式不同

4.3 结合Test.java中的main函数,简述面向接口编程的好处。

  1. Test.java中的代码明显简洁很多
  2. main函数面向StudenDao,输入数据时无需考虑后台是什么。

5. 什么是面向接口编程?面向接口编程的好处是什么?

  • 面向接口编程使用了接口多态性的特性,通过定义一组接口,只向上层传递接口功能,上层对于下层仅仅通过接口联系,而不是一一通过类联系。
  • 好处:
  1. 简化代码,使整个程序看起来更简洁;
  2. 当下层的类需要修改甚至一整个换掉时,只要接口功能没有变化,上层不用做任何修改;
  3. 使用面向接口更利于团队合作。

3.码云及PTA

3.1 码云代码提交记录

3.2 截图PTA题集完成情况图

3.3 统计本周完成的代码量

周次 总代码量 新增代码量 总文件数 新增文件数
1 0 0 0 0
2 0 0 0 0
3 0 0 0 0
4 0 0 0 0
5 322 322 5 5
6 729 407 12 7

Week06-继承、多态、抽象类与接口的更多相关文章

  1. Java入门系列之类继承、抽象类、接口(五)

    前言 C#和Java关于类.抽象类.接口使用方式基本相似,只是对应关键字使用不同罢了,本节呢,我们只是对照C#和Java中关于这三个概念在具体使用时,看看有哪些不一样的地方. 类继承 C#和Java在 ...

  2. 第二十八节:Java基础-进阶继承,抽象类,接口

    前言 Java基础-进阶继承,抽象类,接口 进阶继承 class Stu { int age = 1; } class Stuo extends Stu { int agee = 2; } class ...

  3. 黑马程序员——【Java基础】——面向对象(一)概述、类与对象、继承、抽象类、接口、多态、内部类

    ---------- android培训.java培训.期待与您交流! ---------- 一.面向对象概述 1.面向对象:是一个很抽象的概念,它相对面向过程而言,是一种程序设计的思想. 2.面向对 ...

  4. 第四课 OOP封装继承多态解析,接口抽象类选择 2019-04-21

    父类 xx = new 子类(); xx.method(); 1 普通方法由编译时决定(左边) --- 提高效率 2 虚方法(virtual)  由运行时决定-- -多态,灵活 3 抽象方法由运行时决 ...

  5. Java 对象的继承,抽象类,接口

    子父级继承 关键字 extends 首先创建一个父类 class Fu { String name; int a=1; public void word() { System.out.println( ...

  6. 《Java技术》第三次作业--面向对象——继承、抽象类、接口

    1.阅读下面程序,分析是否能编译通过?如果不能,说明原因.应该如何修改?程序的运行结果是什么?为什么子类的构造方法在运行之前,必须调用父 类的构造方法?能不能反过来? class Grandparen ...

  7. python之路----继承的抽象类和接口类

    抽象类与接口类 接口类 继承有两种用途: 一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类Interface,接口类中定义了一些接口名(就是函数 ...

  8. Java之继承、抽象类、接口篇

    一.继承(extends) 什么是继承? 继承是对现实生活中的"分类"概念的一种模拟. 狮子拥有动物的一切基本特性,但同时又拥有自己的独特的特性,这就是"继承" ...

  9. Java中多态、抽象类和接口

    1:final关键字(掌握) (1)是最终的意思,可以修饰类,方法,变量. (2)特点: A:它修饰的类,不能被继承. B:它修饰的方法,不能被重写. C:它修饰的变量,是一个常量. (3)面试相关: ...

  10. 记录:JAVA抽象类、接口、多态

    JAVA抽象类.接口.多态 1. 多态 定义 多态是同一个行为具有多个不同表现形式或形态的能力.(多态就是同一个接口,使用不同的实例而执行不同操作) 如何实现多态 继承和接口 父类和接口类型的变量赋值 ...

随机推荐

  1. 第六篇 .NET高级技术之拆箱装箱

    拆箱.装箱 值类型赋值给Object类型变量的时候,会发生装箱:包装成Object.ValueType不也是继承自Object吗(CLR内部处理): Object类型变量赋值给值类型赋值的时候会发生拆 ...

  2. hdu1301 Jungle Roads 基础最小生成树

    #include<iostream> #include<algorithm> using namespace std; ; int n, m; ]; struct node { ...

  3. hdu1879 继续畅通工程 基础最小生成树

    #include <cstdio> #include <cstdlib> #include <algorithm> #include <cmath> u ...

  4. LCA+树状数组 POJ 2763 Housewife Wind

    题目传送门 题意:两种操作,问u到v的距离,并且u走到了v:把第i条边距离改成w 分析:根据DFS访问顺序,将树处理成链状的,那么回边处理成负权值,那么LCA加上BIT能够知道u到v的距离,BIT存储 ...

  5. Aappcloud 调到二级页面黑屏

    PartnerHead3.html 后面多了一个点

  6. CF982C Cut 'em all!

    思路: 在深搜过程中,贪心地把树划分成若干个连通分支就可以了.划分的条件是某个子树有偶数个节点.注意到在一次划分之后并不需要重新计数,因为一个数加上一个偶数并不影响这个数的奇偶性. 实现: #incl ...

  7. 【学习笔记】OSG 基本几何图元

    例:geom->addPrimitiveSet(new osg::DrawArrays(osg::PrimitiveSet::QUADS,0,4)); 来指定要利用这些数据生成一个怎么样的形状. ...

  8. 009全志R16平台tinav3.0下编译不过的问题

    009全志R16平台tinav3.0下编译不过的问题 2018/11/13 11:39 版本:V1.0 开发板:SC3817R SDK:tina v3.0 1.01原始编译全志r16平台tinav3. ...

  9. React-Native 开发问题整理

    1.内嵌WebView,点击输入框后页面不自动上滚 <activity android:name=".MainActivity" android:label="@s ...

  10. COGS 2274. [HEOI 2016] tree

    ★☆   输入文件:heoi2016_tree.in   输出文件:heoi2016_tree.out   简单对比时间限制:1 s   内存限制:128 MB 这道题数据弱到炸了 . 第一次做用树刨 ...