类的继承
1.类的继承就是在现有类的基础上,派生出一个新的类,新派生的类自动具有了现有类的全部属性和特征,同时,新类还加入了原有类所没有的新的属性、特征和方法,所以可以说新类是对原有类的扩展。
在继承关系中,被继承的类称为父类(或基类),通过继承产生的类称为子类(派生类)。Java中不允许多继承,只存在单继承,一个类只可以有一个父类。
子类和父类是相对而言的,一个子类也可以成为另外一个类的父类。如动物可以是一个父类,动物中有飞禽、陆生动物、水生动物都拥有动物所具有的属性。一个子类可以是一个父类的对象,而一个父类不一定是一个子类的对象。子类和父类如一般和具体,普通和特殊的关系。
继承的格式为 :public class 子类名 extends 父类名。
父类的非私有性方法可以默认继承给子类,子类不可以调用父类中的私有方法,父类的构造方法子类不可以继承.
如果子类和父类同一个包下,则除私有的属性和方法外,其他都能被调用;如果子类父类在不同包中,但对象在子类外去调用方法,只有公有的方法和属性能被调用;如果不同包下,但是在子类中调用,则公有的和受保护的都能被调用。
以下范围依次由严到宽:
private :本类访问;
default :表示默认,不仅本类访问,而且是同包可见。
Protected:同包可见+不同包的子类可见
Public :表示所有的地方均可见。
2.方法重写
在Java中,子类可继承父类中的方法,而不需要重新编写相同的方法。但有时子类并不想原封不动地继承父类的方法,而是想作一定的修改,这就需要采用方法的重写。方法重写又称方法覆盖。
关于方法重写的特性:
1)发生方法重写的两个方法返回值、方法名、参数列表必须完全一致(子类重写父类的方法)
2)子类方法的访问级别不能低于父类相应方法的访问级别(子类访问级别不能低于父类访问级别)
3.自动转型
自动转型的格式为:
public 返回值类型 方法名(父类名 子类变量名)
父类名 变量名=new 子类名();
方法 方法名(子类变量名);
4.多态性
多态:多态指的是编译时类型变化,而运行时类型不变。
多态分两种:
① 编译时多态:编译时动态重载;
② 运行时多态:指一个对象可以具有多个类型。
对象是客观的,人对对象的认识是主观的。
运行时多态的三原则:(应用时为覆盖)
1、 对象不变;(改变的是主观认识)
2、 对于对象的调用只能限于编译时类型的方法,如调用运行时类型方法报错。
在上面的例子中:Animal a=new Dog();对象a的编译时类型为Animal,运行时类型为dog。 注意:编译时类型一定要为运行时类型的父类(或者同类型)。
对于语句:Dog d=(Dog)a。将d强制声明为a类型,此时d为Dog(),此时d就可以调用运行时类型。注意:a和d指向同一对象。
3、 在程序的运行时,动态类型判定。运行时调用运行时类型,即它调用覆盖后的方法。
下面为英雄联盟一个回合制游戏,可选英雄有徳玛西亚之力和卡牌大师,直到一方血量为0游戏结束:
1.英雄父类
package netJava0711徳玛卡牌; public class Role {//英雄父类 private double blood; private double defense; private double attack; private String name; public Role(String n,double x,double y,double z){ name=n; blood=x; attack=y; defense=z; } public void setName(String s){ name=s; } public String getName(){ return name; } public void setBlood(double d){ blood=d; } public double getBlood(){ return blood; } public void setAttack(double d){ attack=d; } public double getAttack(){ return attack; } public void setDefense(double d){ defense=d; } public double getDefense(){ return defense; } public void Q(Role n1,Role n2){ } public void W(Role n1,Role n2){ } public void E(Role n1,Role n2){ } public void R(Role n1,Role n2){ } }
2.徳玛西亚之力子类英雄:
package netJava0711徳玛卡牌; public class Garen extends Role{ public Garen(String n, double x, double y, double z) { super(n, x, y, z); } public void Q(Role b,Role p){ double HP=b.getBlood()-130-p.getAttack()*1.4+b.getDefense(); b.setBlood(HP); System.out.println(b.getName()+"受到了"+p.getName()+"致命打击技能的伤害,血量减少"+(130+p.getAttack()*1.4-b.getDefense())+",被沉默一个回合,男爵血量剩余"+HP+"点"); } public void W(Role p,Role n){ p.setBlood(p.getBlood()+300); System.out.println(p.getName()+"获得一个持续性的防御护盾,增加"+p.getName()+"300点血量"); } public void E(Role b,Role p){ double HP=b.getBlood()-p.getAttack()*1.1-120; b.setBlood(HP); System.out.println(p.getName()+"快速的旋舞大剑,每回合对"+b.getName()+"造成"+(p.getAttack()*1.1+120)+"点加上盖伦攻击力的110%点物理伤害,持续1回合。" +b.getName()+"血量剩余"+HP+"点"); } public void R(Role b,Role p){ double HP=b.getBlood()-525+b.getDefense(); b.setBlood(HP); System.out.println(p.getName()+"召唤徳玛西亚之力,试图斩杀"+b.getName()+",造成"+b.getName()+(525-b.getDefense())+"点魔法伤害。" +b.getName()+"血量剩余"+HP+"点"); } }
3.卡牌大师子类英雄:
package netJava0711徳玛卡牌; public class Garen extends Role{ public Garen(String n, double x, double y, double z) { super(n, x, y, z); } public void Q(Role b,Role p){ double HP=b.getBlood()-130-p.getAttack()*1.4+b.getDefense(); b.setBlood(HP); System.out.println(b.getName()+"受到了"+p.getName()+"致命打击技能的伤害,血量减少"+(130+p.getAttack()*1.4-b.getDefense())+",被沉默一个回合,男爵血量剩余"+HP+"点"); } public void W(Role p,Role n){ p.setBlood(p.getBlood()+300); System.out.println(p.getName()+"获得一个持续性的防御护盾,增加"+p.getName()+"300点血量"); } public void E(Role b,Role p){ double HP=b.getBlood()-p.getAttack()*1.1-120; b.setBlood(HP); System.out.println(p.getName()+"快速的旋舞大剑,每回合对"+b.getName()+"造成"+(p.getAttack()*1.1+120)+"点加上盖伦攻击力的110%点物理伤害,持续1回合。" +b.getName()+"血量剩余"+HP+"点"); } public void R(Role b,Role p){ double HP=b.getBlood()-525+b.getDefense(); b.setBlood(HP); System.out.println(p.getName()+"召唤徳玛西亚之力,试图斩杀"+b.getName()+",造成"+b.getName()+(525-b.getDefense())+"点魔法伤害。" +b.getName()+"血量剩余"+HP+"点"); } }
4.主函数:
package netJava0711徳玛卡牌; import java.util.Random; public class War { public void init(Role n1,Role n2){ Random r1=new Random(); Random r2=new Random(); Random r3=new Random(); while(n1.getBlood()>0&&n2.getBlood()>0){ int i1=r1.nextInt(1); int i2=r2.nextInt(4); int i3=r3.nextInt(4); if(i1==0){ switch(i2){ case 0:n1.Q(n2,n1);break; case 1:n1.W(n1,n2);break; case 2:n1.E(n2,n1);break; case 3:n1.R(n2,n1);break; } switch(i3){ case 0:n2.Q(n1,n2);break; case 1:n2.W(n2,n1);break; case 2:n2.E(n1,n2);break; case 3:n2.R(n1,n2);break; } } else if(i1==1){ switch(i3){ case 0:n2.Q(n1,n2);break; case 1:n2.W(n2,n1);break; case 2:n2.E(n1,n2);break; case 3:n2.R(n1,n2);break; } switch(i2){ case 0:n1.Q(n2,n1);break; case 1:n1.W(n1,n2);break; case 2:n1.E(n2,n1);break; case 3:n1.R(n2,n1);break; } } } if(n1.getBlood()>0) System.out.println(n1.getName()+"斩杀"+n2.getName()+"!!!"); else System.out.println(n1.getName()+"死亡!!!T.T"); } public static void main(String[] args) { Garen dema1=new Garen("我方盖伦",500,500,100); Garen dema2=new Garen("敌方盖伦",300,80,80); Twisted kapai1=new Twisted("我方崔斯特",300,120,80); Twisted kapai2=new Twisted("敌方崔斯特",250,100,60); War w1=new War(); w1.init(dema1,kapai1); } }
相关推荐
"Qt5类继承关系图"是一个重要的参考资料,它直观地展示了Qt5库中各个类之间的关系,有助于开发者理解和使用Qt5的各种组件。 这个PDF文档很可能包含了Qt5的主要模块,如Qt Widgets、Qt GUI、Qt Network、Qt Database...
`Student` 类继承自 `UniversityObject`,并实现了 `getSummary()` 函数。该函数返回学生的注册号和姓名组成的字符串。构造函数接受两个字符串参数,分别用于初始化 `name` 和 `register_str` 成员变量。通过这种...
QT类继承图是Qt框架中的一个重要组成部分,它展示了Qt库中各类之间的层次结构,帮助开发者理解和使用Qt的各种组件。在编程领域,类继承是面向对象编程的一个核心概念,通过继承,一个类(子类)可以获取另一个类...
标题“PyQt5类继承图”指向了这一主题,它旨在揭示PyQt5框架下各类之间的层次结构。 首先,`Qt5类继承图.pdf`文件很可能是该主题的核心,它可能包含了一个详细的图表,显示了PyQt5中的所有主要类是如何从Qt库的基础...
QT4中的类继承关系是理解其内部工作原理和高效开发的关键。 在QT4中,类的继承关系构建了一个庞大的类层次结构,使得开发者可以方便地利用已有的功能,同时扩展自定义的功能。核心类如`QObject`是许多其他类的基础...
类继承和动态内存分配是C++编程中两个重要的概念,它们在实际开发中结合使用时,可以实现更灵活和高效的设计。在这个主题中,我们将深入探讨如何在类继承的环境中运用动态内存分配,并通过示例代码来理解这三种情况...
"Qt类继承图"揭示了Qt库中类之间的关系,这些类构成了一个强大的层次结构。这个图通常包括Qt的主要模块,如Core、Gui、Widgets、Network、Sql、Qml等。每个模块都包含了一系列相关的类,这些类通过继承来实现功能的...
本话题主要探讨的是Hibernate 3.2版本中的类继承关系处理,这是面向对象编程中常见的概念,但在数据库映射时需要特殊考虑。在Hibernate中,类继承关系的处理允许我们创建更加灵活和可扩展的对象模型。 在Hibernate ...
qt43-类继承关系图.pdf qt43-类继承关系图.pdf qt43-类继承关系图.pdf qt43-类继承关系图.pdf
QT4.1 类库的类继承关系图,jpg格式
c++类继承关系 Hierarchy Chart 继承关系 基类CObject派生出的各类,MSDN中用
根据提供的文件信息,我们可以梳理出以下知识点,主要围绕Qt框架以及其在C++中的类继承关系、模块划分、以及相关的技术概念。 首先,我们注意到文档提到了“Qt5类继承关系图”,这暗示了文档中可能包含Qt 5版本中...
"C++类继承内存布局详解图" C++类继承内存布局是一种复杂的机制,涉及到类的继承、成员变量的访问、成员函数的访问、虚函数调用、强制转换到基类或虚基类等多个方面。在本文中,我们将从C结构的布局开始,逐步介绍...
Qt5.1类继承关系图,免费资源 。
在VC++编程环境中,类继承是面向对象编程的一个核心概念,它允许我们创建新的类,这些新类可以扩展或修改已存在的类的功能。这个过程被称为派生,派生类(子类)从基类(父类)继承特性,从而实现代码的重用和功能的...
AS3的类继承树和中文API是开发者学习和理解AS3核心概念的重要参考资料。 首先,让我们来深入了解一下AS3中的类继承。在面向对象编程中,类继承是一种机制,允许一个类(子类或派生类)从另一个类(父类或基类)继承...
明了的Qt5类继承明了的Qt5类继承
知识星球Sariel分享,类继承绕过。可轻松过D盾。反正现在能用
**Qt5类继承关系图详解** Qt5是一个强大的跨平台应用程序开发框架,广泛应用于桌面、移动设备和嵌入式系统的GUI设计。它以其丰富的类库、高效的性能和易用性著称。在Qt5中,类的继承关系是理解其工作原理的关键。本...
在C++编程语言中,类继承是面向对象编程的一个核心概念。它允许我们创建一个新类,该类基于已存在的类(称为基类或父类),并在此基础上扩展功能或修改行为。通过继承,我们可以实现代码重用,设计更加灵活的类结构...