Java 基础知识杂记

最近很久没去看Java基础知识了..偶尔有时间看了一下 Think in Java .发现自己还根本是很多不懂啊..汗!!
记载一下最近的学习所得 
1.继承
  在衍生类的构建器中,Java会自动插入对基础类构建器的调用
 



Art {
Art() {
System.out.println();
}
}

Drawing Art {
Drawing() {
System.out.println();
}
}

Cartoon Drawing {
Cartoon() {
System.out.println();
}
main(String[] args) {
Cartoon x = Cartoon();
}
}

该程序的输出显示了自动调用:

Art constructor
Drawing constructor
Cartoon constructor
可以看出,构建是在基础类的“外部”进行的,所以基础类会在衍生类访问它之前得到正确的初始化。
即使没有为Cartoon()创建一个构建器,编译器也会为我们自动合成一个默认构建器,并发出对基础类构建器的调用。

对于含有自变量的构建器
上述例子有自己默认的构建器;也就是说,它们不含任何自变量。编译器可以很容易地调用它们,因为不存在具体传递什么自变量的问题。如果类没有默认的自变 量,或者想调用含有一个自变量的某个基础类构建器,必须明确地编写对基础类的调用代码。这是用super关键字以及适当的自变量列表实现的,

关于衍生类的垃圾.首先都是先消除子类对基类的引用,然后一级一级地向上清除基类, 垃圾回收的过程正好与创建类的时候相反




2.final和static 字段修饰
  final 修饰的字段 强行要求我们对final进行赋值处理——要么在定义字段时使用一个表达 式,
 要么在每个构建器中。这样就可以确保final字段在使用前获得正确的初始化
 Static强调它们只有一个;而final表明它是一个常数
 final自变量
Java 1.1允许我们将自变量设成final属性,方法是在自变量列表中对它们进行适当的声明。这意味着在一个方法的内部,我们不能改变自变量句柄指向的东西

6.9.1 继承初始化
我们有必要对整个初始化过程有所认识,其中包括继承,对这个过程中发生的事情有一个整体性的概念。请观察下述代码:



Insect {
i = 9;
j;
Insect() {
prt( + i + + j);
j = 39;
}
x1 =
prt();
prt(String s) {
System.out.println(s);
47;
}
}

Beetle Insect {
k = prt();
Beetle() {
prt( + k);
prt( + j);
}
x2 =
prt();
prt(String s) {
System.out.println(s);
63;
}
main(String[] args) {
prt();
Beetle b = Beetle();
}
}

该程序的输出如下:
 Insect.x initialized
Beetle.x initialized
Beetle constructor
i = 9, j = 0
Beetle.k initialized
k = 63
j = 39

对Beetle 运行Java时,发生的第一件事情是装载程序到外面找到那个类。在装载过程中,装载程序注意它有一个基础类(即extends关键字要表达的意思),所以 随之将其载入。无论是否准备生成那个基础类的一个对象,这个过程都会发生(请试着将对象的创建代码当作注释标注出来,自己去证实)。
若基础类含有另一个基础类,则另一个基础类随即也会载入,以此类推。接下来,会在根基础类(此时是Insect)执行static初始化,再在下一个衍生类执行,以此类推。保证这个顺序是非常关键的,因为衍生类的初始化可能要依赖于对基础类成员的正确初始化。
此 时,必要的类已全部装载完毕,所以能够创建对象。首先,这个对象中的所有基本数据类型都会设成它们的默认值,而将对象句柄设为null。随后会调用基础类 构建器。在这种情况下,调用是自动进行的。但也完全可以用super来自行指定构建器调用(就象在Beetle()构建器中的第一个操作一样)。基础类的 构建采用与衍生类构建器完全相同的处理过程。基础顺构建器完成以后,实例变量会按本来的顺序得以初始化。最后,执行构建器剩余的主体部分。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值