课后作业
1.对象变量也可以使用“==”判断两变量值是否相等吗?
如果是引用类型的对象作比较,则比较对象地址、字符串和数字比较值是否相等。
2.请总结一下这个方法有哪些“与众不同之处”,你能列出几条?;
1.方法名与类名相同
2.方法名首字母大写。
3.请输入并运行以下代码,得到什么结果?
public class Test {
public static void main(String[] args) {
// TODO 自动生成的方法存根
Foo obj1=new Foo();
Foo obj2=new Foo();
System.out.println(obj1==obj2);
}
}
class Foo{
int value=100;
}
4.以下代码为何无法通过编译?哪儿出错了?
类提供了一个自定义的构造方法,系统不再提供默认构造方法
5.如果一个类中既有初始化块,又有构造方法,同时还设定了字段的初始值,谁说了算?
谁靠后就是谁初始化起作用。
执行类成员定义时指定的默认值或类的初始化块,到底执行哪一个要看哪一个“排在前面”。
6.使用上页幻灯片中定义的类,以下代码输出结果是什么?
请依据代码的输出结果,自行总结Java字段初始化的规律。
(1)执行类成员定义时指定的默认值或类的初始化块,到底执行哪一个要看哪一个“排在前面”。
(2)执行类的构造函数。类的初始化块不接收任何的参数,而且只要一创建类的对象,它们就会被执行。因此,适合于封装那些“对象创建时必须执行的代码”
7.请运行TestStaticInitializeBlock.java示例,观察输出结果,总结出“静态初始化块的执行顺序”
class Root
{
static{
System.out.println("Root的静态初始化块");
}
{
System.out.println("Root的普通初始化块");
}
public Root()
{
System.out.println("Root的无参数的构造器");
}
}
class Mid extends TestStaticInitializeBlock
{
static{
System.out.println("Mid的静态初始化块");
}
{
System.out.println("Mid的普通初始化块");
}
public Mid()
{
System.out.println("Mid的无参数的构造器");
}
public Mid(String msg)
{
//通过this调用同一类中重载的构造器
this();
System.out.println("Mid的带参数构造器,其参数值:" + msg);
}
}
class Leaf extends Mid
{
static{
System.out.println("Leaf的静态初始化块");
}
{
System.out.println("Leaf的普通初始化块");
}
public Leaf()
{
//通过super调用父类中有一个字符串参数的构造器
super("Java初始化顺序演示");
System.out.println("执行Leaf的构造器");
}
}
public class TestStaticInitializeBlock
{
public static void main(String[] args)
{
new Leaf();
}
}
创建Java对象时,系统总是先调用静态初始化块,静态初始化块是类相关的,用于对整个类进行初始化处理,静态初始化块也属于类的静态成员,因此不能访问非静态成员.
8.静态方法中只允许访问静态数据,那么,如何在静态方法中访问类的实例成员(即没有附加static关键字的字段或方法)?
public class test {
private static test_instance = null;
public static test getinstance()
{
if(null == _instance)
_instance = new test();
return _instance;
}
}
请看以下的“神奇代码”
两对整数明明完全一样,为何一个输出true,一个输出false?
第一次比较的的地址是取自同一个地址的数字,而第二次比较的数是创建了两个不同地址的对象