java成员变量的前期绑定例子

Java的引用变量有两个类型,一个是编译时类型,一个是运行时类型,编译时类型由声明该变量时使用的类型决定,运行时类型由实际赋给该变量的对象决定。 如果编译时类型和运行时类型不一致,会出现所谓的多态。因为子类其实是一种特殊的父类,因此java允许把一个子类对象直接赋值给一个父类引用变量,无须任何类型转换,或者被称为 向上转型,由系统自动完成。    引用变量在编译阶段只能调用其编译时类型所具有的方法,但运行时则执行它运行时类型所具有的方法,因此,编写Java代码时,引用变量只能调用声明该变量所用类里包含的方法。与方法不同的是,对象的属性则不具备多态性。通过引用变量来访问其包含的实例属性时,系统总是试图访问它编译时类所定义的属性,而不是它运行时所定义的属性。  前期绑定和后期绑定(动态绑定、运行时绑定):绑定:将一个方法调用同方法主体关联起来叫做绑定 前期绑定:在程序执行之前进行绑定(如果有的话,由 编译器连接器完成),前期绑定是面向过程程序设计语言中默认的绑定方式,例如,C语言只有一种方法调用,那就是前期绑定。 后期绑定:就是在程序运行时根据对象的类型进行绑定,也叫作动态绑定或运行时绑定。注意:Java中除了static和final方法(private方法属于final方法,因为类中的private方法被隐式指定为final方法,由此我们也可以知道:将方法 声明为final类型的一是为了防止方法被覆盖,二是为了有效的关闭 java中的动态绑定)之外,其他方法都是后期绑定。这意味着通常不必判定是否该进行后期绑定,因为它是自动发生的。





  1. class A
  2. {
  3. int count = 20;
  4. }

  5. class B extends A
  6. {
  7. int count = 200;
  8. }

  9. public class Test
  10. {
  11. public static void main(String[] args)
  12. {
  13. A a = new A();
  14. System.out.println(a.count);
  15. B b = new B();
  16. System.out.println(b.count);
  17. A ab = b; //向上转型
  18. System.out.println(ab.count);
  19. }
  20. }

  21. 运行结果 :
  22. 20
  23. 200
  24. 20
  25. 结果分析:

        前两行的输出毫无疑问,问题在

        A ab = b;

        System.out.println(ab.count);

        的输出是20,而不是200;在这之间我们可以用

        System.out.println(ab == b);

        来进行简单的判断,结果输出为 true ,说明 ab 和 b 两个引用变量指向同一个实例,既然 ab 和 b 指向同一个实例,为什么输出的是20不是200呢?原因在于:

        1.对于 class A 和class B来说,class B是class A的子类,由于子类的变量并不会覆盖父类的变量,所以实际上在class B中是存在来两个count,在这分别记作 A.count 和B.count ;

        2.虽然在 class B中存在A.count 和B.count ,但是究竟输出那一个 count ,取决于该引用变量的声明时类型(本文开头红色文字部分已经说明),此处 声明时类型 是 class A,所以输出 20 即A.count ,同理若改为 B ab = b ;则输出 200 即 B.count ;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值