学习要点

  • 多态的优势和应用场合
  • 父类和子类之间的类型转换
  • instanceof运算符的使用
  • 父类作为方法形参实现多态
  • 父类作为返回值实现多态

使用多态的原因

需求描述:

在宠物管理系统中,宠物饿了,需要主人给他喂食,不同的宠物吃不一样的东西,并且健康值恢复情况也不一样。

狗狗:吃狗粮,吃完后健康值增加3。

企鹅:吃鱼,吃完后健康值增加5。

问题分析:

狗狗类:增加狗狗吃食的方法

企鹅类:增加企鹅吃食的方法

创建主人类:编写给狗狗喂食的方法,编写给企鹅喂食的方法

编写测试方法:调用主人类给狗狗喂的方法,调用主人类给企鹅喂的方法

编码实现

public class Master {

       public void feed( Dog dog ) {

              dog.eat();

       }

             public void feed( Penguin pgn ) {

               pgn.eat();

       }

             public void feed( XXX xxx ) { //如果增加其他宠物…….

               xxx.eat();

       }

}

  

 编码实现存在的问题

  1. 随着宠物的增多,代码需要不断修改,代码可扩展性太差。
  2. 主人喂食方法的参数都是Pet子类,是否可以采用feed(Pet pet)实现?
  3. 使用多态实现!

多态

生活中的多态

都是打印机,但是不同类型的打印机,打印出的效果是不同的。

同一事物,由于条件不同,产生的结果也是不同的。

程序中的多态

多态:同一个引用类型,使用不同的实例而执行不同操作。程序中使用父类定义引用,使用子类对象运行。

feed(Pet pet);  //pet实际指向dog、penguin、cat等对象

  

如何使用多态

  1. 编写父类
  2. 编写子类,子类重写父类方法
  3. 运行时,使用父类的类型,子类的对象(黄色部分为实现多态两个要素)
向上转型:Pet pet = new Dog();// 自动类型转换

  

实现多态的两种形式

使用父类作为方法形参实现多态

使用父类作为方法返回值实现多态

上机练习

使用多态实现宠物管理系统的喂食。

增加猫,猫吃猫粮,健康值增加5。

使用父类作为方法返回值实现多态//工厂模式

使用多态实现宠物领养

使用父类作为方法返回值

实现思路

在Master类添加领养方法getPet(String typeId )

创建测试类,根据主人选择宠物类型编号来领养宠物。

父类到子类的转换

问题描述

实现主人与宠物玩耍功能

和狗狗玩接飞盘游戏,狗狗的健康值减少10,与主人亲密度增加5。

和企鹅玩游泳游戏,企鹅的健康值减少10,与主人亲密度增加5。

问题分析

给Dog添加接飞盘方法catchingFlyDisc( )

给Penguin添加游泳方法swimming( )

给主人添加play(Pet pet)方法

代码实现以及问题

向下转型(强制类型转换)

为了避免类型转换报错,使用instanceof运算符进行类型判断,判断的结果为布尔值类型。

语法结构:

对象  instanceof  类或接口

使用场合:instanceof通常和强制类型转换结合使用。

上机练习

优化宠物管理系统,使用多态实现主人领养宠物并与宠物玩耍。

  1. 主人根据宠物编号领养宠物。
  2. 主人和狗狗玩接飞盘游戏,狗狗健康值减少10,与主人亲密度增加5。
  3. 主人和企鹅玩游泳游戏,企鹅健康值减少10,与主人亲密度增加5。

总结

多态可以减少类中代码量,可以提高代码的可扩展性和可维护性

  • 向上转型——子类转换为父类,自动进行类型转换
  • 向下转型——父类转换为子类,结合instanceof运算符进行强制类型转换

实现多态的两种方式

  • 使用父类作为方法形参实现多态
  • 使用父类作为方法返回值实现多态

JavaSE-10 多态的更多相关文章

  1. Javase中多态polymorphic的简单介绍

    -------------多态-----------------  (1)面向对象三大核心思想:    1.封装 2.继承 3.多态 (2)多态定义:父类的引用指向子类的对象.   (3)引用指的是父 ...

  2. javase(10)_多线程基础

    一.排队等待 1.下面的这个简单的 Java 程序完成四项不相关的任务.这样的程序有单个控制线程,控制在这四个任务之间线性地移动.此外,因为所需的资源 ― 打印机.磁盘.数据库和显示屏 -- 由于硬件 ...

  3. javaSE第九天

      第九天    50 1. final关键字(掌握)    50 (1)定义:    50 (2)特点:    51 (3)面试相关:    51 A:final修饰的局部变量    51 B:fi ...

  4. JavaSE_ 面向对象 总目录(7~10)

    JavaSE学习总结第07天_面向对象2 07.01 成员变量和局部变量的区别07.02 方法的形式参数是类名的调用07.03 匿名对象的概述和应用07.04 封装的概述07.05 封装的好处和设计原 ...

  5. JavaSE学习总结第09天_面向对象4

      09.01 final关键字引入 例: class Fu { public final void show() { System.out.println("访问底层资源"); ...

  6. java四大特性理解(封装继承多态抽象)

    封装: 封装是把过程和数据包围起来,对数据的访问只能通过已定义的接口.面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治.封装的对象,这些对象通过一个受保护的接口访问其他对象.封装是一 ...

  7. c#之字符串,列表,接口,队列,栈,多态

    1.字符串的用法 using System; using System.Collections.Generic; using System.Linq; using System.Text; using ...

  8. JavaSE日常笔记汇总

    1. If和switch的比较 2. continue的注意事项 在for循环中,当执行continue语句时,i++还是会执行,continue语句只代表此次循环结束,i还是会累加,并继续执行下次循 ...

  9. JDK 9 & JDK 10 新特性

    JDK 9 新增了不少特性,官方文档:https://docs.oracle.com/javase/9/whatsnew/toc.htm#JSNEW-GUID-527735CF-44E1-4144-9 ...

  10. Java中的继承、封装、多态的理解

    Java中的继承.封装.多态 继承的理解: 1.继承是面向对象的三大特征之一,也是实现代码复用的重要手段.Java的继承具有单继承的特点,每个子类只有一个直接父类. 2.Java的继承通过extend ...

随机推荐

  1. NSArray, NSSet, NSDictionary

    一.Foundation framework中用于收集cocoa对象(NSObject对象)的三种集合分别是: NSArray 用于对象有序集合(数组)NSSet 用于对象无序集合(集合) NSDic ...

  2. 在 Ubuntu 16.04 中安装支持 CPU 和 GPU 的 Google TensorFlow 神经网络软件

    TensorFlow 是用于机器学习任务的开源软件.它的创建者 Google 希望提供一个强大的工具以帮助开发者探索和建立基于机器学习的应用,所以他们在去年作为开源项目发布了它.TensorFlow ...

  3. AutoIT: 通过页面抓取来陈列任务管理器里面所有进程的列表

    #include<Array.au3> $handle =WinGetHandle("Windows 任务管理器") ;$ctrl =ControlGetHandle( ...

  4. TCP/IP协议的建立连接与关闭连接过程

    一.建立连接(三次握手) 第一次握手:建立连接时,客户端发送SYN(seq=x)包到服务器,并进入SYN_SENT状态,等待服务器的确认.SYN:同步序列编号(Synchronize Sequence ...

  5. win10下的jdk1.8安装

    1 下载jdk 下一步就好 默认C盘最好 不要又中文  http://pan.baidu.com/s/1eSwvFA6(这里面有两个jdk 32位 64位) 看图 CLASSPATH: .;%JAVA ...

  6. C# 混淆 反编译

    .net破解一(反编译,反混淆-剥壳) http://www.cnblogs.com/jio92/p/de4dot.html C#学习系列-String与string的区别 http://www.cn ...

  7. bzoj 4195: [Noi2015]程序自动分析【并查集】

    等于有传递性,所以hash一下把等于用并查集连起来,然后再判断不等于是否合法即可 #include<iostream> #include<cstdio> #include< ...

  8. bzoj 2087: [Poi2010]Sheep【凸包+极角排序+dp】

    首先处理处理出来哪些边能连--能把羊分成两个偶数部分的,实现是在凸包上枚举极点,极角排序,枚举凸包上点对判断两边羊的个数的奇偶即可,设可以连边为v[i][j]=1 然后设f[i][j]为从i到j个凸包 ...

  9. bzoj 1609[Usaco2008 Feb]Eating Together麻烦的聚餐【dp】

    设up[i][j]为第i位升序为j的最小修改数,down为降序 #include<iostream> #include<stdio.h> using namespace std ...

  10. 把pdf传给kindle

    对于不是纯文本的,最好主题不要用convert,虽说用了之后可以转换为大小更合适的字体,但是会破坏本来PDF的格式,变得更加不合适阅读