要求设计一个方法,要求此方法可以接受A类的任意子类对象,并调用方法,此时,如果不使用对象多态性,那代码肯定会类似如下

class A{ // 定义类A public void Run1(){ // 定义Run1()方法 System.out.println("A类----Run1方法") ; } public void Run2(){ Run1() ; // 调用父类的Run1()方法 }}class B extends A{ public void Run1(){ // 覆写父类中的Run1方法 System.out.println("B类----Run1方法") ; } public void Run3(){ // B类特有的方法 System.out.println("B类----Run3方法") ; }}class C extends A{ public void Run1(){ // 覆写父类中的Run1方法 System.out.println("C类----Run1方法") ; } public void Run5(){ // C类特有的方法 System.out.println("C类----Run5方法") ; }}public class Demo6{ public static void main(String asrgs[]){ Run(new B()) ;// 传递B类的实例 B b = new B(); Run(new C()) ;// 传递C类的实例 C c = new C(); } public static void Run(B b){ b.Run1() ; // 调用覆写父类中的Run1()方法 } public static void Run(C c){ c.Run1() ; // 调用覆写父类中的Run1()方法 }}复制代码

以代码虽然实现要求,但可以发现:如果按照如上方式完成程序,这就相当于产生了一个A类的子类时,Run()方法就要重载一次,则每一次扩充子类都要修改类本身,这样肯定不太好,那么如果使用对象多态性完成呢?具体代码如下

class A{ // 定义类A public void Run1(){ // 定义Run1()方法 System.out.println("A类----Run1方法") ; } public void Run2(){ Run1() ; // 调用父类的Run1()方法 }}class B extends A{ public void Run1(){ // 覆写父类中的Run1方法 System.out.println("B类----Run1方法") ; } public void Run3(){ // B类特有的方法 System.out.println("B类----Run3方法") ; }}class C extends A{ public void Run1(){ // 覆写父类中的Run1方法 System.out.println("C类----Run1方法") ; } public void Run5(){ // C类特有的方法 System.out.println("C类----Run5方法") ; }}public class Demo6{ public static void main(String asrgs[]){ Run(new B()) ;// 传递B类的实例,产生向上转移 Run(new C()) ;// 传递C类的实例,产生向上转移 } //接收父类对象 public static void Run(A a){//相当于 A a = new B() & A a = new C() a.Run1() ; // 调用覆写父类中的Run1()方法 } }复制代码

上代码中在Run()方法中使用了对象的多态性,所以可以接收任何子类的对象,这样无论子类如何增加,Run()方法都不用做任何的改变,因为发生了对象的向上转型关系后,调用的方法一定是被子类覆写过的方法。