java盡自己的全力保證所有變量都能在使用前得到正确的初始化。若被定義成相對于一個方法的“局部”變量,這一保證就通過編譯期的出錯提示表現出來。是以,如果使用下述代碼:
![](https://img.laitimes.com/img/__Qf2AjLwojIjJCLyojI0JCLicmbw5iNiVWYhBjYzAjZzUmNhJDN2ADN4QzYkJDO3UjMygzN08CX0JXZ252bj91Ztl2Lc52YucWbp5GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.png)
void f() {
int i;
i++;
}
就會收到一條出錯提示消息,告訴你i可能尚未初始化。當然,編譯器也可為i賦予一個預設值,但它看起來更象一個程式員的失誤,此時預設值反而會“幫倒忙”。若強迫程式員提供一個初始值,就往往能夠幫他/她糾出程式裡的“臭蟲”。
然而,若将基本類型(主類型)設為一個類的資料成員,情況就會變得稍微有些不同。由于任何方法都可以初始化或使用那個資料,是以在正式使用資料前,若還是強迫程式員将其初始化成一個适當的值,就可能不是一種實際的做法。然而,若為其賦予一個垃圾值,同樣是非常不安全的。是以,一個類的所有基本類型資料成員都會保證獲得一個初始值。可用下面這段小程式看到這些值:
//: InitialValues.java
// Shows default initial values
class Measurement {
boolean t;
char c;
byte b;
short s;
int i;
long l;
float f;
double d;
void print() {
System.out.println(
"Data type Inital value\\n" +
"boolean " + t + "\\n" +
"char " + c + "\\n" +
"byte " + b + "\\n" +
"short " + s + "\\n" +
"int " + i + "\\n" +
"long " + l + "\\n" +
"float " + f + "\\n" +
"double " + d);
}
}
public class InitialValues {
public static void main(String[] args) {
Measurement d = new Measurement();
d.print();
}
} ///:~
輸入結果如下:
Data type Inital value
boolean false
char
byte 0
short 0
int 0
long 0
float 0.0
double 0.0
其中,Char值為空(NULL),沒有資料列印出來。
稍後大家就會看到:在一個類的内部定義一個對象句柄時,如果不将其初始化成新對象,那個句柄就會獲得一個空值。