先看一段代码:

abstract class A{                public A(){                this.print();        }                public abstract void print();}class B extends A{        private int x=100;                public B(int x){                this.x=x;        }                public void print(){                System.out.println("x="+x);        }}public class Test01{                public static void main(String args[]){                A a=new B(10);                B b=new B(90);                b.print();        }        }  

输出结果:

x=0
x=0
x=90

现在分析一下原因:

A a=new B(10);时先调用B的构造函数,但是B继承自A,所以B构造函数执行之前先执行A(),A()中的this.print();会调到B类里的void print()。

而这时,B的构造还没完成,x还没初始化。所以打印出来是x的默认值0;

B b=new B(90);的原理同上,打印出来也是0;

b.print(); 这时b已经完成初始化。所以传进去的90,打印出来也是90

更多相关文章

  1. Android Audio代码分析2 - 函数getMinBufferSize
  2. android关于fragment的构造函数用法建议
  3. Android Audio代码分析18 - setSampleRate函数
  4. Android Audio代码分析22 - AudioEffect::getEnabled函数
  5. Android初始化OpenGL ES,并且分析Renderer子线程原理
  6. android初始化activity时隐藏软键盘
  7. Android——编译系统初始化设置
  8. android初始化部分:how to java2Cpp

随机推荐

  1. 自适应不同分辨率的屏幕大小、方向和不同
  2. 腾讯Bugly热更新集成总结
  3. 利用GridView实现单选功能
  4. 0828 - 精简 Lua 绑定第一步
  5. Android中 LogCat 信息消失
  6. 「Android」Lenovo K860 root脚本备忘
  7. Android中多线程的用法
  8. Ubuntu下eclipse连接手机
  9. Android手机客户端访问.NET服务器端的方
  10. android中配置文件property的用途以及使