A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 刘一锋 黑马帝   /  2013-6-22 23:47  /  1733 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

我不知道是不是我对多态的理解不到家,要是说狗是狗也是动物,这我能理解,但是要是说重载和覆盖也体现了多态的话,我就有点想不明白了,谁能帮忙解释一些,谢谢了

评分

参与人数 1技术分 +1 收起 理由
袁梦希 + 1 很给力!

查看全部评分

4 个回复

倒序浏览
是指允许不同类的对象对同一消息作出响应。很好的解决了应用程序函数同名的问题。
方法的重写与重载是java多态性的不同表现,重写是父类与子类之间多态性的一种表现,重载是一个类中多态性的一种表现。如果在子类中定义的某方法与其父类有相同的名称和参数,该方法被重写。子类的对象使用这个方法时,将调用子类中的定义,对它而言,父类中的定义如同被“屏蔽“了。如果在一个类中定义了多个同名的方法,它们或有不同参数个数或有不同的参数类型,则称为方法的重载。

评分

参与人数 1技术分 +1 收起 理由
张勇1993 + 1 赞一个!

查看全部评分

回复 使用道具 举报
左耳的鱼 发表于 2013-6-23 00:07
是指允许不同类的对象对同一消息作出响应。很好的解决了应用程序函数同名的问题。
方法的重写与重载是java ...

我是明白重写和重载的定义和区别的,我只是不知道他们怎么就体现了多态而已,在学习这里的知识的时候一般般只会加上一句,重写和重载体现了多态,关键是在哪体现了?要是说道生活中的多态,我很容易理解,可是程序里的多态就.....
回复 使用道具 举报
override是重写(覆盖)了一个方法,以实现不同的功能。一般是用于子类在继承父类时,重写(重新实现)父类中的方法。
重写(覆盖)的规则:
   1、重写方法的参数列表必须完全与被重写的方法的相同,否则不能称其为重写而是重载.
   2、重写方法的访问修饰符一定要大于被重写方法的访问修饰符(public>protected>default>private)。
   3、重写的方法的返回值必须和被重写的方法的返回一致;
   4、重写的方法所抛出的异常必须和被重写方法的所抛出的异常一致,或者是其子类;
   5、被重写的方法不能为private,否则在其子类中只是新定义了一个方法,并没有对其进行重写。
   6、静态方法不能被重写为非静态的方法(会编译出错)。

overload是重载,一般是用于在一个类内实现若干重载的方法,这些方法的名称相同而参数形式不同。
重载的规则:
   1、在使用重载时只能通过相同的方法名、不同的参数形式实现。不同的参数类型可以是不同的参数类型,不同的参数个数,不同的参数顺序(参数类型必须不一样);
   2、不能通过访问权限、返回类型、抛出的异常进行重载;
   3、方法的异常类型和数目不会对重载造成影响;

多态的概念比较复杂,有多种意义的多态,一个有趣但不严谨的说法是:继承是子类使用父类的方法,而多态则是父类使用子类的方法。
一般,我们使用多态是为了避免在父类里大量重载引起代码臃肿且难于维护。

评分

参与人数 1技术分 +1 收起 理由
袁梦希 + 1 很给力!

查看全部评分

回复 使用道具 举报
我给你说说我的理解、多态就多种形态吧、比如成员函数的重载(Overload)意思就是在一个类内,允许有多个“函数名”相同,但“参数列”不同的成员函数、我给你发一个我的代码、你看看能不能了然哈、
  1. class a07
  2. {               
  3.         public int getAverage(int value1,int value2) //注意这里的方法类型
  4.         {
  5.                 int average;
  6.                 average = (value1 + value2)/2;                       
  7.                 return average;
  8.         }

  9.         public double getAverage(double value1,double value2) //注意这里的方法类型
  10.         {
  11.                 double average;
  12.                 average = (value1 + value2)/2;       
  13.                 return average;
  14.         }
  15.        
  16.   public static void main(String[] para)
  17.   {
  18.                
  19.                 a07 aa= new a07();
  20.                 System.out.println(aa.getAverage(55,90));
  21.                 System.out.println(aa.getAverage(55.5,92.0));
  22.                      
  23.   }
  24. }
复制代码
这不就实现多态了么

至于覆盖嘛、也差不多吧、成员函数的覆盖就是“子类”内可以定义与“父类”内同名(函数名+参数列)的成员函数,这样是“覆盖”继承
而来的成员函数、不过这个时候要注意的还挺多了、理论我就不给你说了、我也说不明白、这个代码你看看有没有必要研究下吧
  1. import java.lang.*;
  2. import java.lang.reflect.Method;

  3. class a12
  4. {         
  5.         public static void main(String[] para)
  6.   {               
  7.     System.out.println("====== A 类之 obj1 对象 ====== ");               
  8.     Aa obj1 = new Aa();   
  9.     obj1.fun1();
  10.     obj1.showAA();
  11.     obj1.showAA(1111);
  12.     System.out.println("obj1.aa = " + obj1.aa);   
  13.    
  14.     System.out.println("====== B1 类之 obj2 对象 ====== ");                          
  15.     B1 obj2 = new B1();
  16.     obj2.fun1();
  17.     obj2.showAA();
  18.     obj2.showAA(3333);
  19.     System.out.println("obj2.aa = " + obj2.aa);
  20.    
  21.     System.out.println("====== B2 类之 obj3 对象 ====== ");                    
  22.     B2 obj3 = new B2();
  23.     obj3.fun1();
  24.     obj3.showAA();
  25.     obj3.showAA(6666);  
  26.     System.out.println("obj3.aa = " + obj3.aa);
  27.    
  28.   }
  29. }

  30. class Aa
  31. {
  32.   public  int aa = 1000;
  33.    
  34.   public  void fun1()
  35.   {
  36.           System.out.println("A 类的 fun1() 方法");
  37.   }
  38.   
  39.   public  void fun2()
  40.   {
  41.           System.out.println("A 类的 fun2() 方法");
  42.   }       
  43.   
  44.   public  void showAA()
  45.   {                                 // 存取 A 类内定义的 aa
  46.           System.out.println("call A class showAA() : aa = " + aa);
  47.   }
  48.   
  49.   public void showAA(int aaValue)
  50.   {
  51.           aa = aaValue;
  52.           System.out.println("call A class showAA(int) : aa = " + aa);
  53.   }
  54. }

  55. class B1 extends Aa
  56. {
  57.   public  String aa = "001-aa";
  58.   
  59.   public void showAA()
  60.   {                                 // 存取 B1 类内定义的 aa
  61.           System.out.println("call B1 class showAA() : aa = " + aa);
  62.   }
  63.   
  64.   public void fun1()
  65.   {  //返回类型一定要一样才能 override,否则会有 error
  66.           System.out.println("B1 类的 fun1() 方法");
  67.   }
  68. }

  69. class B2 extends Aa
  70. {         
  71.   public String aa = "002-aa";
  72.   public int bb = 300;
  73.    
  74.   public final void fun1()
  75.   {     //修饰字不同一样也是 override
  76.     System.out.println("B2 类的 fun1() 方法");  
  77.     bb = bb + 10;
  78.     System.out.println("bb = " + bb);
  79.   }
  80.   
  81.   public void fun2(String str)
  82.   {   //不算 fun2() 的 overload,也不是 override
  83.           System.out.println(str + "B2 类的 fun2() 方法");
  84.   }
  85. }

复制代码

评分

参与人数 1技术分 +1 收起 理由
神之梦 + 1 很给力!代码的注释可以再详细点,方便提问.

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马