1.以下代码为何无法通过编译?哪儿出错了?
在Foo类中已经有了一个Foo的含参构造方法,所以在定义Foo类对象时不能使用new Foo()方法。在Foo类中再写一个无参构造方法,就能编译了。
如果类提供了一个自定义的构造方法,将导致系统不再提供默认构造方法。
2.使用上页幻灯片中定义的类,以下代码输出结果是什么?自行总结Java字段初始化的规律。
输出结果:
规律:
类的初始化块,可以在类中使用“{”和“}”将语句包围起来,直接将其作为类的成员。类的这种“没有名字”的“成员”,多用于初始化类的字段。
public int field=100; 在定义时进行初始化,此时field = 100;System.out.println(obj.field); 输出field的值100。
obj=new InitializeBlockClass(300);System.out.println(obj.field);利用构造方法进行初始化,field的值初始化为300,输出300。
3.请运行TestStaticInitializeBlock.java示例,观察输出结果,总结出“静态初始化块的执行顺序”。
输出结果:
总结:所有的静态初始化块都优先执行,其次才是非静态的初始化块和构造函数,它们的执行顺序是:父类的静态初始化块>子类的静态初始化块>父类的初始化块>父类的构造函数>子类的初始化块>子类的构造函数.
4.静态方法中只允许访问静态数据,那么,如何在静态方法中访问类的实例成员(即没有附加static关键字的字段或方法)?
public class Example { int a = 1;//类的实例变量,初始化值为1
static int b = 2;//类的静态变量,初始化值为2
public static void method()//静态方法
{
System.out.println("实例变量a = " + new Example().a);//在静态方法中访问类的实例变量需首先进行类的实例化
System.out.println("静态变量b = " + b);//在静态方法中可直接访问类的静态变量
} public static void main(String[] args)
{
Example.method();
Example ex = new Example();
System.out.println("a = " + ex.a);
}
}
结果截图: