课后作业 2

1.请输入并运行以下代码,得到什么结果??、

==”施加于原始数据类型变量时,是比较变量所保存的数据是否相等==”施加于引用类型变量时,是比较这两个变量是否引用同一对象。因为obj1 obj2是类Foo的两个对象,所以此时比较的是两个对象的地址,所以输出false

2.

 

一是执行类成员定义时指定的默认值或类的初始化块,到底执行哪一个要看哪一个“排在前面”,二是执行类的构造函数。

3.

class Root

{

static{

System.out.println("Root的静态初始化块");

}

{

System.out.println("Root的普通初始化块");

}

public Root()

{

System.out.println("Root的无参数的构造器");

}

}

class Mid extends Root

{

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();

}

}

静态初始化块只执行一次。创建子类型的对象时,也会导致父类型的静态初始化块的执行。先执行父类静态初始化块然后再执行自己这个类的静态初始化块。

4.

 

类提供了一个自定义的构造方法,将导致系统不再提供默认构造方法。因为下面的Foo类中提供出了自己的构造方法,所以用new默认构造方法不再提供使用。

5.


public class Example
{
int x = 3;//类的实例变量,初始化值为3
static int y = 4;//类的静态变量,初始化值为4
public static void method()//静态方法
{
System.out.println("实例变量x = " + new Example().x);//在静态方法中访问类的实例变量需首先进行类的实例化
System.out.println("静态变量y = " + y);//在静态方法中可直接访问类的静态变量
}

public static void main(String[] args)
{
Example.method();
Example ex = new Example();
System.out.println("x = " + ex.x);
}
}

运行结果:

类中静态的方法或者属性,本质上来讲并不是该类的成员,在java虚拟机装在类的时候,这些静态的东西已经有了对象,它只是在这个类中"寄居",不需要通过类的构造器(构造函数)类实现实例化;而非静态的属性或者方法,在类的装载是并没有存在,需在执行了该类的构造函数后才可依赖该类的实例对象存在。

在外部调用静态方法时,可以使用"类名.方法名"的方式,也可以使用"对象名.方法名"的方式。而实例方法只有后面这种方式。也就是说,调用静态方法可以无需创建对象。

静态方法在访问本类的成员时,只允许访问静态成员(即静态成员变量和静态方法),而不允许访问实例成员变量和实例方法;实例方法则无此限制。

  public static void main(String[] args) 

{

  Example.method();

  Example ex = new Example();

System.out.println("x = " + ex.x);

}

}

6.

public class ceshi {
private int id;
private String name;
private static long count;
private final static ThreadLocal tl=new ThreadLocal();

public ceshi() {
super();
count++;
tl.set(count);
}
public long getCount(){
return (Long)tl.get();
}
public static void main(String[] args) {
for (int i = 0; i < 5; i++) {
ceshi t=new ceshi();
System.out.println(t.getCount());
}
}

}

原文地址:https://www.cnblogs.com/muxiaozhou/p/5984294.html