(2.1.14)java的多态:重载与覆盖

0-作用域

重载与覆盖只针对成员函数,不针对成员变量
overload编译时的多态
override运行时的多态.

1-重载与覆盖的区别

1、方法的覆盖是子类和父类之间的关系,是垂直关系;方法的重载是同一个类中方法之间的关系,是水平关系。
2、覆盖只能由一个方法,或只能由一对方法产生关系;方法的重载是多个方法之间的关系。
3、覆盖要求参数列表相同;重载要求参数列表不同。
4、覆盖关系中,调用那个方法体,是根据对象的类型(对象对应存储空间类型)来决定;重载关系,是根据调用时的实参表与形参表来选择方法体的。
override可以翻译为覆盖,从字面就可以知道,它是覆盖了一个方法并且对其重写,以求达到不同的作用。对我们来说最熟悉的覆盖就是对接口方法的实现,在接口中一般只是对方法进行了声明,而我们在实现时,就需要实现接口声明的所有方法。除了这个典型的用法以外,我们在继承中也可能会在子类覆盖父类中的方法。在覆盖要注意以下的几点:
1、覆盖的方法的标志必须要和被覆盖的方法的标志完全匹配,才能达到覆盖的效果;
2、覆盖的方法的返回值必须和被覆盖的方法的返回一致;
3、覆盖的方法所抛出的异常必须和被覆盖方法的所抛出的异常一致,或者是其子类;
4、被覆盖的方法不能为private,否则在其子类中只是新定义了一个方法,并没有对其进行覆盖。
5、子类继承至少要权限满足父类即可 父类是public 子类只能是public
overload对我们来说可能比较熟悉,可以翻译为重载,它是指我们可以定义一些名称相同的方法,通过定义不同的输入参数来区分这些方法,然后再调用时,VM就会根据不同的参数样式,来选择合适的方法执行。在使用重载要注意以下的几点:
1、在使用重载时只能通过不同的参数样式。例如,不同的参数类型,不同的参数个数,不同的参数顺序(当然,同一方法内的几个参数类型必须不一样,例如可以是fun(int, float), 但是不能为fun(int, int));
2、不能通过访问权限、返回类型、抛出的异常进行重载;
3、方法的异常类型和数目不会对重载造成影响;

2-成员函数的多态性

class Base{
  public Base(){
    g();
    }
  public void f(){
  cout<<"Base f()";
  }
  public void g(){
    cout<<"Base g()";
  }
  }

class Derived extends Base{
  public void f(){
  cout<<"Derived f()";
  }
  public void g(){
    cout<<"Derived g()";
  }
  }

public Class Test{
public static void main(string[] arg){
Base b=new Derived();//(1)Derived g()
b.f();//(2)Derived f()
b.g();//(3)Derived g()
}
}

(1)Derived g()
Base b=new Derived();调用base的构造函数,在base中执行g()函数,由于java的多态性,会调用子类的Derived g()
(2)(3)
创建的是子类,直接调用子类的方法

成员变量的非多态性

class Base{
public int i=1;
}
class Derived extends Base{
public int i=11;
}
public Class Test{
public static void main(string[] arg){
Base b=new Derived();
cout<<b.i;//输出1,base类型,指向base类中的i
}
}

成员变量是无法实现多态的,成员变量的取值是父类还是子类并不是取决于具体创建的对象示例,而是取决于定义的变量类型,这是在编译时就已确认的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值