第四章:
1、primitive类型的重载慎用。
(chap4、P7)
2、返回值不能重载,因为存在虽然方法有返回值,但程序中并不关注返回值的情况,如:
定义:int f(){}; String f(){};
调用 f(),此时虚拟机就不知道该调用哪个f了。
(chap4、P11)
3、类中的普通方法不能调用构造函数,构造函数能相互调用,但只能用this要害字。
(chap4、P13)
4、一般来说,类中无需使用finalize(),因为虚拟机会自动进行垃圾清理,但有种非凡情况,声明了一个对象,但并没有refrence,比如:
class Aclass(){....};
...
new Aclass();
因为没有refrence,那么虚拟机会认为它已经没有用了,就可以回收了,但此时假如你不希望它回收,那么可以在finalize函数中实现,具体可参考书本的例子。
(chap4、P16)
5、内部变量在使用之前必须初始化;所谓“使用”是指出现在表达式右边、方法的参数等,而不是表达式的左边,例如:
String s = "i love Java";
int i;
i = s.length();
是正确的;而
int i;
i++;
是错误的。因为i++相对于i = i + 1
但是,假如不是内部变量而是类的的成员数据,则不需要初始化,因为编译器不知道会在哪个方法中被初始化。对于primitive的成员数据,Java会自动赋予初始值,如:
boolean = false
char = (char)0 ----空格
byte = 0
int = 0
long = 0
float = 0
double = 0
对于对象的成员数据,没有初始化之前等于null,所以,primitive的成员数据没有初始化之前被使用并不会发生错误,但对象数据在运行时就会发生exception。
有一种非凡情况,如:
int [] a = new int[4];
此时,看上去只初始化了数组的大小而没有初始化数组的成员,但在java中,这也是没有问题的,java给每个数组成员自动进行了初始化。
(chap4,P22)
6、类实例化的时候总是先执行成员数据的定义(假如在定义的时候进行初始化的话此时就初始化了),然后再执行构造函数,而不管在代码顺序上成员数据在前还是构造函数在前。
(chap4,P26)
7、对于static类型的成员变量,static类型的成员变量总是比其他成员变量先初始化,static类型的成员变量只初始化一次,只有被用到的static成员变量才会被初始化。
此处,“被用到”在我来理解,是从main函数开始检查的,假如main函数中定义了静态变量或者被main函数调用的其他类中定义了静态变量,这些静态变量就“被用到”了。
(chap4,P27)
8、primitive类型的数组可以用new来初始化,如int[] a = new int[]{1,2,3,4},也可以直接用形如int[] a = {1,2,3,4}的方式来初始化,但假如不是primitive的变量就只能用new来初始化。
(chap4,P34)
9、数组初始化的时候,int[] a = {1,2,3,4,}; 4后面有逗号,对不对?答:对,最后的逗号有与没有都可以。
(chap4,P35)