20172311 2017-2018-2 《程序设计与数据结构》第八周学习总结

20172311 2017-2018-2 《程序设计与数据结构》第八周学习总结

教材学习内容总结

本周对JAVA中的多态性进行了学习

  • 多态性引用能够随时间变化指向不同类型的对象,是通过后绑定实现的。
  • 实现多态性的主要途径有两种:
    1.由继承实现多态性
    2.利用接口实现多态性
  • 使用多态解决方法的问题:
    1.排序:
    (1)选择法排序
    (2)插入法排序
    2.搜索:
    (1)线性搜索
    (2)二分搜索
  • 多态性设计:
    多态性允许用一致性的方法实现不一致性的行为,应该训练自己的软件设计敏感性,善于识别能利用多态性解法的潜在问题。

教材学习中的问题和解决过程


问题1:例题10.2中的(Executive)和(Hourly)能否去掉?

例10.2的代码如下:

public class Staff
{private StaffMember[] staffList;//-----------------------------------------------------------------//  Constructor: Sets up the list of staff members.//-----------------------------------------------------------------public Staff(){staffList = new StaffMember[6];staffList[0] = new Executive("Sam", "123 Main Line","555-0469", "123-45-6789", 2423.07);staffList[1] = new Employee("Carla", "456 Off Line","555-0101", "987-65-4321", 1246.15);staffList[2] = new Employee("Woody", "789 Off Rocker","555-0000", "010-20-3040", 1169.23);staffList[3] = new Hourly("Diane", "678 Fifth Ave.","555-0690", "958-47-3625", 10.55);staffList[4] = new Volunteer("Norm", "987 Suds Blvd.","555-8374");staffList[5] = new Volunteer("Cliff", "321 Duds Lane","555-7282");//题目中提到的问题处:((Executive)staffList[0]).awardBonus(500.00) ;((Hourly)staffList[3]).addHours(40);}//-----------------------------------------------------------------//  Pays all staff members.//-----------------------------------------------------------------public void payday (){double amount;for (int count=0; count < staffList.length; count++){System.out.println(staffList[count]);amount = staffList[count].pay();  // polymorphicif (amount == 0.0)System.out.println("Thanks!");elseSystem.out.println("Paid: " + amount);System.out.println("-----------------------------------");}}
} 
  • 问题一解决方案:
    通过分析类图解决问题,类图如下:

1332980-20180502012740963-2071992146.jpg

  • 理解:首先Staff类中实例化的是一个StaffMember类的数组通过类图可以看到StaffMember类中的pay()方法是抽象的,在派生出来的Volunteer和Employee类中得到了实现,最终又在Executive和Hourly类中进行了方法的重写。也就是说(Executive)和(Hourly)不能去掉,如果去掉,首先StaffMember类中不存在pay()方法,是不成立的。总结一下就是多态情况下可能存在很多重名的方法,要在前面声明方法来自哪个类从而对具体类的具体方法使用。

问题2:对于利用接口实现多态性的理解模糊

  • 问题2解决方案:
    通过搜集资料了解到:
    接口相当于一种约束,它里面只包含了属性、方法的定义,而没有具体实现,这点类似一个抽象类,但是与抽象类不同的时它不能包含有已经实现的方法。比如:
public interface IInterfaceExample 
{ 
int Property1 {get;set;} 
string Test(); 
}   

里面的成员不用写修饰符,是因为所有里面的都是可以对外公开的内容,都是 public 的。
它的本意是为多个不同的对象规定一个通用的规范,最常见的莫过于用来实现多态了。
通过这个接口,调用者无须知道目标对象的具体详细信息,只需要知道它实现了这个接口,那么它便可以依据这个接口来使用这个对象了。

  • 参考资料
    理解接口
  • 接口具体使用的实例
//真的鸭子会游泳 木头鸭子不会游泳 橡皮鸭子会游泳//不同的鸭子游泳的方式不一样,所以在父类中我不知道怎么实现,所以这里考虑使用接口的方法public interface ISwimming{void Swim();}public class RealDuck implements ISwimming{public void Swim(){System.out.println("真的鸭子靠翅膀游泳");}}public class XPDuck implements ISwimming{public void Swim(){System.out.println("橡皮鸭子飘着游泳");}}public class MuDuck { //这里因为木头鸭子不会游泳,所以不继承接口也就不用实现接口中的方法}  
  • 在Main方法中调用一下
static void Main(string[] args){ISwimming swim = new XPDuck();//new RealDuck();swim.Swim();//橡皮鸭子飘着游泳
}

其实会发现接口和抽象类实现多态很相似,只是接口更加注重的是方法的实现

上面提到接口和接口之间可以继承,并且接口可以继承多个接口,那么如果一个类继承了一个有多继承的接口时,这个类中需要将所有继承链上的方法全部实现

就像下面酱紫

 public interface M1{void Test1();}public interface M2{void Test2();}public interface M3{void Test3();}
//下面这个接口继承了多个接口public interface SupperInterface implements M1, M2, M3{ }
//这个类继承了一个有多个继承的接口,所以需要实现继承链上的所有方法public class Car implements SupperInterface{public void Test1(){throw new NotImplementedException();}public void Test2(){throw new NotImplementedException();}public void Test3(){throw new NotImplementedException();}}
  • 参考资料
    使用接口

问题三:看不懂课本上给出的排序和搜索的例题

  • 问题三解决方案:
    通过做项目pp10.4加深了对例题的理解
    pp10.4项目代码链接
  • 理解:以排序为例:在例10.10的Contact类中引用了一个Comparable接口,构造了equalscompareTO方法,而在例10.9的Sorting类则定义了选择排序和插入排序的方法,最终在例10.8的驱动类PhoneList类中实现了对Contact对象的递增排序。是多态性的一个典型的运用。

代码调试中的问题和解决过程

问题1:编写项目pp10.5时遇到较大麻烦,数次修改都没有成功,问题截图如下:

1332980-20180502010139942-2092673743.png

  • 问题1解决方案:通过与课本上例题的仔细对比终于发现是自己的一时疏忽造成的。
  • 问题代码截图如下:
    1332980-20180502010202837-34873367.png

  • 改正过后的代码截图如下:
    1332980-20180502010218267-77123903.png

代码托管

1332980-20180501233719219-250981736.jpg

上周考试错题总结

  • 错题1
    1332980-20180502011205112-1276582312.png
  • 理解:重载只是为具有不同参数列表的方法提供了替代方法。重写提供了多态性,因为根据当前正在引用的对象调用适当的方法。嵌入是类中的类的封闭。抽象与多态性无关。封装是通过使用可见性修饰符(公共的、私有的、受保护的)实现的。
  • 错题2
    1332980-20180502011504198-363760682.png
  • 理解: 虽然继承和接口支持多态性,但只有在具有后期绑定的情况下才会这样做。但是重载是多态性的一种形式(方法)名称,多个主体,因此只要程序使用重载,多态性就会被使用。
  • 错题3
    1332980-20180502011811124-813977108.png
  • 理解:通过每一个比较,二分查找消除了大约一半的剩余数据。这个过程将继续,直到找到找到的元素,或者直到所有可能的数据都被删除为止。由于有n个数据元素,所以在数据量小于一个元素之前,可以将数据减半的次数为log2n。
  • 错题4
    1332980-20180502012120440-1737717390.png
  • 理解:精确!由于println()在本质上是高度多态的,它能够正确地打印各种预定义的(库)和内置(原始)数据。
  • 错因:大脑短路!!!
  • 错题5
    1332980-20180502012251346-1837618304.png
  • 理解:方法的参数可以是多态的,使方法能够灵活地控制其参数。要实现这一点,只需使用接口名称或基类名称来声明变量。然后,参数是多态的,在执行过程中引用类的正确实例,并在执行期间访问正确的语义。

结对及互评

点评过的同学博客和代码

  • 本周结对学习情况
    • 20172307

    • 结对学习内容
      这周和黄宇瑭童鞋的结对学习情况可以说是落实的比较到位了,我们两个一起讨论四则运算项目的整体思路,共同设计类图,共同输入代码,在输入的时候进行交流,从而发现问题所在。希望以后再接再厉吧!!

    • 上周博客互评情况
    • 20172305
    • 20172302
    • 20172301
    • 20172328
    • 20172316
    • 20172314
    • 20172319

感悟

唯有努力坚持,才有可能见到理想的彼岸!!继续努力吧!!

学习进度条

代码行数(新增/累积)博客量(新增/累积)学习时间(新增/累积)重要成长
目标5000行30篇400小时
第一周28/281/116/16
第二周710/7381/220/36
第三周426/11641/316/52
第四周1068/22322/520/72
第五周604/29281/622/94
第六周609/35371/722/116
第七周599/41361/818/134
第八周1052/51883/1120/154
  • 计划学习时间:18小时

  • 实际学习时间:20小时

  • 改进情况:继续努力,充分发挥结对编程的重大作用!

参考资料

  • 《Java程序设计与数据结构教程(第二版)》

  • 《Java程序设计与数据结构教程(第二版)》学习指导

  • 蓝墨云班课资源
  • 举例:接口的定义,实现,为什么要用接口,意义何在?
  • 接口实现多态

转载于:https://www.cnblogs.com/zhaoxiaohai/p/8978085.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/251815.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux系统安装Apache 2.4.6

http://www.cnblogs.com/kerrycode/p/3261101.html Apache简介 Apache HTTP Server&#xff08;简称Apache&#xff09;是Apache软件基金会的一个开放源码的网页服务器&#xff0c;可以在大多数计算机操作系统中运行&#xff0c;由于其多平台和安全性被广泛使用&#xff0c;是最…

lnmp化境开启pathinfo,支持tp5.0等访问

一、 开启pathinfo   #注释 下面这一行 #include enable-php.conf #载入新的配置文件 include enable-php-pathinfo.conf #添加如下location / {if (!-e $request_filename){rewrite ^/(.*)$ /index.php/$1 last;break;}}location ~ /index.php {fastcgi_pass 127.0.0.1:…

openfire(一):使用idea编译openfire4.2.3源码

最近公司项目要使用openfire&#xff0c;并对源码做一些修改&#xff0c;使用的openfire版本为官网目前最新版本4.2.3&#xff0c;网上资料较少&#xff0c;踩了很多坑&#xff0c;特此记录。 1.下载源码 http://www.igniterealtime.org/downloads/source.jsp 2.使用idea导入源…

[BZOJ] 1688: [Usaco2005 Open]Disease Manangement 疾病管理

1688: [Usaco2005 Open]Disease Manangement 疾病管理 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 727 Solved: 468[Submit][Status][Discuss]Description Alas! A set of D (1 < D < 15) diseases (numbered 1..D) is running through the farm. Farmer John woul…

Image-to-Image Translation with conditional Adversarial Networks ---- Pix-2-Pix

任务场景 Photos to semantic segmentationCityscapes labels to photosColorizationFacades labels to photoDay to nightThe edges to photoAnd so on.在生成器模型中&#xff0c;条件变量y实际上是作为一个额外的输入层&#xff08;additional input layer&#xff09;&…

5分钟从零构建第一个 Apache Flink 应用

为什么80%的码农都做不了架构师&#xff1f;>>> 在本文中&#xff0c;我们将从零开始&#xff0c;教您如何构建第一个Apache Flink &#xff08;以下简称Flink&#xff09;应用程序。 开发环境准备 Flink 可以运行在 Linux, Max OS X, 或者是 Windows 上。为了开发…

Android6.0------权限申请RxPermissions

前面写了Android6.0权限介绍和权限单个&#xff0c;多个申请&#xff0c;用的是纯Java代码&#xff0c;本文主要说的是借助第三方库来实现权限申请。 借助第三方库 RxPermissions来申请6.0权限。 RxPermissions库地址&#xff1a;https://github.com/tbruyelle/RxPermissions …

博客作业04--树

1.学习总结(2分) 1.1树结构思维导图 1.2 树结构学习体会 树这一章节比较复杂&#xff0c;知识点繁多&#xff0c;结合了递归的知识所以代码阅读起来会有障碍&#xff0c;难以理解&#xff0c;所以学起来比较吃力&#xff0c;而且很多经典的算法理解的不是很透彻解决pta上的问题…

[DP/单调队列]BZOJ 2059 [Usaco2010 Nov]Buying Feed 购买饲料

首先我想吐槽的是题目并没有表明数据范围。。。 这个题目 DP方程并不难表示。 dp[i][j]表示前i个地点携带了j个货物的最小花费 dp[i][j] dp[i-1][k] (j-k) * cost j*j*(leng[i]-leng[i-1]) 如果你这样直接提交上去&#xff0c;恭喜你超时&#xff01;&#xff01;&#xff0…

039_MySQL_多表查询

#创建部门 CREATE TABLE IF NOT EXISTS dept (did int not null auto_increment PRIMARY KEY,dname VARCHAR(50) not null COMMENT 部门名称 )ENGINEINNODB DEFAULT charset utf8;#添加部门数据 INSERT INTO dept VALUES (1, 教学部); INSERT INTO dept VALUES (2, 销售部); IN…

4.navicat11激活教程,亲测可用哦!

原文地址&#xff1a;http://blog.csdn.net/sanbingyutuoniao123/article/details/52589678Navicat是一款数据库管理工具, 用于简化, 开发和管理MySQL, SQL Server, SQLite, Oracle 和 PostgreSQL 的数据库&#xff1b;Navicat数据模型工具以图形化方式创建关联式数据库&#x…

想要去阿里面试?你必须得跨过 JVM 这道坎!

概述 很多人想要到阿里巴巴、美团、京东等互联网大公司去面试&#xff0c;但是现在互联网大厂面试一般都必定会考核JVM相关的知识积累和实践经验&#xff0c;毕竟线上系统写好代码部署之后&#xff0c;每个工程师都必须关注JVM相关的东西&#xff0c;比如OOM、GC等问题. 所以一…

医学知识图谱一

大纲 知识自动提取技术 医学知识融合 医学知识推理 转载于:https://www.cnblogs.com/quietwalk/p/9000950.html

在一个div里,列表样式图片进行float,实现水平排序

<div class"xiangce"><ul> <li><a href"#"><img src"images/pic4.gif" alt"">产品名称</a></li><li><a href"#"><img src"images/pic4.gif" alt"…

The listener supports no services

$ lsnrctl start 报错提示: The listener supports no services The command completed successfully 如图所示&#xff1a; 这样启动后远程连接会报错&#xff1a; oracle ORA-12514:TNS:listener does not currently know of service requested in connect descriptor 问题原…

SEO【总结】by 2019年5月

2019独角兽企业重金招聘Python工程师标准>>> 关键点&#xff1a; 1、代码 1.1、seo前端代码&#xff1a;基于Html代码的SEOherf&#xff1a;https://my.oschina.net/u/2862573/blog/3030664 注意的要点&#xff1a; h1&#xff0c;h2的内容很关键 网页的压缩、静态化…

Oracle数据库 查看表是否是 索引组织表的方法

1. 最近在工作过程中发现 一个表插入很慢 以为是索引组织表, 所以一直有点纠结 但是发现 产品里面是没有IOT的 于是找了下公司的OCP 问了下 如何查看 就是 user_tables 视图里面的一个字段. 见图: 转载于:https://www.cnblogs.com/jinanxiaolaohu/p/9018037.html

Windows server 2016 搭建RDS服务

计算机的更新换代太快&#xff0c;新购置的计算机没几年便觉得运行速度越来越慢&#xff0c;尤其是在运行一些比较大的应用程序是&#xff0c;用户总是抱怨运行速度太慢或者总是死机等问题。如果要更换新的计算机&#xff0c;又得不到领导的批准&#xff0c;因此对于企业来说&a…

springboot2.0 多数据源整合问题 At least one JPA metamodel must be present!   at

2019独角兽企业重金招聘Python工程师标准>>> 数据源代码&#xff1a; 第一个读取配置文件代码&#xff1a; package com.datasource;import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.sp…

docker实战系列之搭建rabbitmq

1.搜索镜像【注&#xff1a;因为我这里采用的是阿里云镜像加速器,所以我直接在阿里云中搜索相关镜像路径】,点击"详情"查看公网拉取路径 2.拉取镜像 docker pull registry.cn-hangzhou.aliyuncs.com/jc/rabbitmq-3 3.查看拉取的镜像 docker images 4.创建并运行容器【…