代码改变世界

动手动脑 类与对象10.19

2017-10-19 22:17  Robortxin  阅读(172)  评论(0编辑  收藏  举报

JAVA 类与对象

 

 

 

 

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.以下代码为何无法通过编译?哪儿出错了?

 

 

 

 

 

类提供了一个自定义的构造方法,就将导致系统不再提供默认构造方法所以Foo obj1 = new Foo()需要添加默认参数。

 

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?

第一次比较的的地址是取自同一个地址的数字,而第二次比较的数是创建了两个不同地址的对象,所以第一次比较的地址相同,第二次不同。