一、聲明局部變量是的一些特性和規則
(1)聲明的局部變量是不會被默認初始化的,成員變量則是會被默認初始化的。例如:
代碼如下:
class Demo {
public static void main(String[] args) {
String s;
System.out.println(s);
}
}
上面的這段示例代碼中,直接輸出s是錯誤的,連編譯都不同通過,因為在main方法中聲明s,這時s是局部變量,不會被默認初始化值,因此在下面直接輸出是有錯誤的。代碼改寫如下即可:
代碼如下:
class Demo {
String s;
public static void main(String[] args) {
System.out.println(s);
}
}
這樣輸出的話就是null了,因為s被聲明為成員變量,因此默認會被初始化值null。
(2)聲明局部變量的前面不能有任何權限訪問修飾符(public、protected和private),只能是friendly的默認友好的,但是可以使用final來修飾局部變量。
二、使用final來修飾基本類型局部變量和引用類型局部變量的區別
(1)final修飾基本類型局部變量的時候,不能對其基本類型的數據值進行修改。因為final修飾的變量是最終的,不能被改變。如下代碼:
代碼如下:
public class Something {
public int addOne(final int x) {
return ++x;
}
}
這裡addOne方法中使用final int x作為參數,下面再對其進行自增是錯誤的。
(2)final修飾引用類型的局部變量的時候,也就是對象。這時可以修改對象中的屬性信息,但是不能修改對象的引用。比如下面的代碼:
代碼如下:
public class Something {
public static void main(String[] args) {
Other o = new Other();
new Something().addOne(o);
}
public void addOne(final Other o) {
o.i++;
}
}
class Other {
public int i;
}
這裡addOne方法接收的參數是一個對象,而在方法體中自增了對象中的屬性 i 的值,而對象的引用地址沒有被修改,因此不會發生錯誤。而如果在方法體中寫上:o = new Other(); 這時就會報錯了。
(3)在類中被final修飾聲明的成員變量不會默認初始化值。因此必須在構造器之前就得給定一個具體值。例如下面的代碼:
代碼如下:
class Something {
final int i;// 這行就已經報錯了,編譯不能通過,沒有初始化值
public void doSomething() {
System.out.println("i = " + i);
}
}
final int i是個final的instant variable (實例變量,或叫成員變量)。final的instant variable沒有default value,必須在constructor (構造器)結束之前被賦予一個明確的值。可以修改為"final int i =0;"。