zoukankan      html  css  js  c++  java
  • Java构造时成员初始化的陷阱

    今天看到一篇标题:“Java构造时成员初始化的陷阱”的文章:http://coolshell.cn/articles/1106.html

    自已写了一个简单的程序测试了一下:

    public final class Test
    {
        public Test()
        {
            B b = new B();  
                 
            System.out.println(b.name);
        }   
             
        class A
        {
            A()
            {
                System.out.println("A()");
                a();        
                     
            }
                 
            void a()
            {
                System.out.println("A.a()");
            }
        }
             
        class B extends A
        {
            public String name= "张三";
                 
            B()
            {           
                System.out.println("B()");
            }
                 
            void a()
            {
                System.out.println("B.a()");
                name = "李四";
            }
        }   
             
        public static void main(String[] args)
        {       
            new Test();     
        }
    }

    运行输出的结果:

    下面是对上面各个步骤的逐条解释:
    进入构造函数。
    为成员变量分配内存。
    除非你显式地调用super(),否则Java 会在子类的构造函数最前面偷偷地插入super() 。
    调用父类构造函数。
    调用B.a(),因为被子类override,所以调用的是子类的。
    于是,初始化发生在了a()之后。这是因为,Java需要保证父类的初始化早于子类的成员初始化,否则,在子类中使用父类的成员变量就会出现问题。
    正式执行子类的构造函数(当然这是一个空函数,虽然我们没有声明)。

    我当时看了也很意外,没想到会是这样的执行顺序和结果。

    2013-05-11

  • 相关阅读:
    ES查询直方图聚合区间结果min越界问题
    yarn命令操作
    Hve on Spark left join的hashTable问题
    基于HUE可视化的大数据权限管理
    Android 制作圆角阴影的卡片
    Android 解决问题“Failed to resolve: com.android.support:design:26.1.0”
    Android 修改虚拟键栏背景颜色
    ArrayList的传值问题
    swift 网络请求中含有特殊字符的解决方案
    Android适配器
  • 原文地址:https://www.cnblogs.com/personnel/p/4584891.html
Copyright © 2011-2022 走看看