实例代码
package text; public class MethodOverload { /** * @param args */ public static void main(String[] args) { InitializeBlockClass obj=new InitializeBlockClass(); System.out.println(obj.field); obj=new InitializeBlockClass(300); System.out.println(obj.field); } } class InitializeBlockClass{ //下面这句在初始化块之前与之后,会影响到field字段的初始值 //public int field=100; { field=200; } public int field=100; public InitializeBlockClass(int value){ this.field=value; } public InitializeBlockClass(){ } }
运行结果
规律(类字段的初始化顺序)
1、执行类成员定义时指定的默认值或类的初始化块,到底执行哪一个要看哪一个“排在前面”。
2、执行类的构造函数。
类的初始化块不接收任何的参数,而且只要一创建类的对象,它们就会被执行。因此,适合于封装那些“对象创建时必须执行的代码”。
以下代码为何无法通过编译?哪儿出错了?
public class Test { public static void main(String[] args) { Foo obj1 = new Foo(); } } class Foo { int value; public Foo (int initValue) { value = initValue; } }
结论:如果类提供了一个自定义的构造方法,将导致系统不再提供默认构造方法。