1.以下代码为何无法通过编译?
package test; public class Test { public static void main(String[] args) { Foo obj1=new Foo(); } } class Foo { int value; public Foo(int initValue) { value=initValue; } }
在类中的构造方法有一个参数,定义对象时没有参数,所以无法通过编译
2. 请依据代码的输出结果,自行总结Java字段初始化的规律
package init; public class InitializeBlockDemo { /** * @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(){ } }
package init; public class InitializeBlockDemo { /** * @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(){ } }
java会在初始化块和构造方法中进行初始化,当对同一变量进行多次初始化时,会按照顺序进行初始化,并保留最后一次的结果。如果在主函数中创建对象时没有形参时,如果在类中定义了公共的变量并给与了赋值,那么就会把值赋给主函数中的变量,再调用类中的默认构造函数,如果在主函数中创建对象时有形参,则调用类中对应的构造函数。
3.观察输出结果,总结出“静态初始化块的执行顺序”
执行顺序:
先执行父类的静态初始化块,在执行子类的静态初始化块,在执行父类的实例初始化块、构造方法,子类的实例初始化块、构造函数。先执行静态,在执行实例和构造方法。
4.静态方法中只允许访问静态数据,那么,如何在静态方法中访问类的实例成员(即没有附加static关键字的字段或方法)?
package test; public class Test { public static void main(String[] args) { Foo.s(); } } class Foo { int value1=1; static int value2=2; public static void s() { System.out.println("value1="+new Foo().value1); System.out.println("value2="+value2); } }
静态方法在访问本类的成员时,只允许访问静态成员,当需要在静态方法中访问本类中的静态成员时,需定义一个该类的对象,然后在方法中通过对象名.静态成员的方法来访问。
5.两对整数明明完全一样,为何一个输出true,一个输出false?
public class StrangeIntegerBehavior { public static void main(String[] args) { Integer i1=100; Integer j1=100; System.out.println(i1==j1); Integer i2=129; Integer j2=129; System.out.println(i2==j2); } }
i1和j1调用了integer中的cache方法,所以i1和j1指向的是同一个对象,所以为true。i2和j2创建了新的对象,指向不同,所以结果是false