歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Java中final局部變量的生命周期

Java中final局部變量的生命周期

日期:2017/3/1 10:48:37   编辑:Linux編程

從C轉Java過來,一些基礎理論不是太扎實,在使用final局部變量時出現了理解錯誤,今天驗證了一下,記下筆記。

  1. public class Main {
  2. public void finalTestFunc() {
  3. final FinalTest t = new FinalTest();
  4. System.out.println("T:" + t.toString());
  5. }
  6. /**
  7. * @param args
  8. */
  9. public static void main(String[] args) {
  10. Main m = new Main();
  11. m.finalTestFunc();
  12. m.finalTestFunc();
  13. }
  14. }

FinalTest是個空類,啥都沒有,toString會轉換成其地址打印出來,上面一段程序的打印:

  1. T:FinalTest@c17164
  2. T:FinalTest@1fb8ee3

可以看到在finalTestFunc()函數中雖然t用final修飾了,但是兩次調用,每次都創建了新的對象,final只是標記了t在本次調用中不能再次指向別的對象,並不代表這個對象始終存在,整個程序生命周期中只初始化一次。

為什麼會有只初始化一次的錯誤理解呢?
其實剛開始使用Java的時候,理解是正確的,認為每次都初始化。
但是後來使用內部類,內部類如果訪問外部類的變量,這個變量就要加final修飾,因為對Java掌握不到位,此時錯誤的認為final將變量的生命周期改為了整個程序生命周期,而實際上此處加final是保證變量值一致性。

同樣在C++中的const也是這個現象,const局部變量的生命周期仍然是局部的,只有加上static才是全局的。

  1. #include <iostream>
  2. using namespace std;
  3. class A {
  4. private:
  5. int v;
  6. public:
  7. A() {
  8. v = 0;
  9. }
  10. void out() const {
  11. cout << "A=" << this << endl;
  12. }
  13. };
  14. class B {
  15. public:
  16. B() {
  17. }
  18. void constTest() {
  19. const A* a = new A();
  20. a->out();
  21. }
  22. };
  23. int main(int,char**) {
  24. B* b = new B();
  25. b->constTest();
  26. b->constTest();
  27. }

這段程序輸出:

  1. A=0x89a8018
  2. A=0x89a8028

即每次函數調用都創建了新的對象,只有加上在const後加上static,才是只初始化一次。

Copyright © Linux教程網 All Rights Reserved