第四章: 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)
|