• 《Think in JAVA》之每日一读(initianlize)——2013/11/12、13


    了解包括继承在内的初始化全过程,以对所发生的的一切有一个全局的把握,是很有益的。

    请看下例:

    package initialize;
    
    class Insect {
    	private int i = 9;
    	protected int j;
    
    	Insect() {
    		System.out.println("i = " + i + ", j = " + j);
    		j = 39;
    	}
    
    	private static int x1 = printInit("static Insect.x1 initialized");
    	static int printInit(String s) {
    		System.out.println(s);
    		return 47;
    	}
    
    }
    
    public class Beetle extends Insect{
    	private int k = printInit("Beelte.k initialized");
    	public Beetle(){
    		System.out.println("k = " + k);
    		System.out.println("j = " + j);
    	}
    	
    	private static int x2 = 
    			printInit("static Beetle.x2 initialized");
    	
    	public static void main(String[] args) {
    		System.out.println("Beetle constructor");
    		//Beetle beetle = new Beetle();	//此处先注释
    	}
    
    }
    

      运行结果:

      

      在运行Beetle时,所发生的第一件事就是试图访问Beetel.main()方法(程序入口)(一个static方法),

    于是加载器就开始启动并找到Beetel类的编译代码(在Beetle.class文件中)。对他进行加载时,发现他有一个基类(这是由“extents”关键字得知的),于是继续进行加载该基类。不管是否你是否打算生成一个该基类的对象,都会发生。从上出代码Beelte.main()方法中的注释代码证明这一点。

      如果该基类还有其自身的基类,那么第二个就会被加载,如此类推。接下来,根基类中的static方法初始化(此例中为Insect)即会被执行,然后是下一个导出类,如此类推。

      至此,必要的类都加载完毕,对象就可以创建了,我们把上面的Beelte.main()方法中的注释代码取消,

      运行结果:

      

    首先对象中所有基本类型都会被设为某默认值,对象引用都设为null,然后基类的构造器会被调用。基类的构造器和导出类的构造器一样,以相同的顺序经历相同的过程。基类构造器完成之后,实例变量按其次序被初始化。

    习题:请证明加载类的动作只发生一次。证明该类的第一个实体的创建或static成员的访问都有可能引起加载。

      在Beelte.main()方法中添加一行代码:

        Beetle beetle2 = new Beetle();

       输出结果:

        

  • 相关阅读:
    Gridview全选
    Gridview中绑定DropDownList
    图片流Base64编码 转图片
    jQuery 效果
    纯虚函数与抽象类
    c++的内存分配
    sizeof数据对齐问题
    C++中类所占的存储空间
    成员函数实现在类定义中与在类定义外的区别
    C++成员函数的存储方式
  • 原文地址:https://www.cnblogs.com/cq-home/p/3420564.html
Copyright © 2020-2023  润新知