<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 42,comments - 83,trackbacks - 0
            有人問我一個關于遞歸的問題, 測試代碼如下:

    TestClass.java
     1 public class TestClass {
     2     
     3     private static TestPrinter printer = null;
     4     
     5     static
     6     {
     7         printStaticInfo("initialize test printer in static");
     8         printer = new TestPrinter();
     9     }
    10     
    11     public TestClass()
    12     {
    13         System.out.println("to construct a TestClass object");
    14     }
    15     
    16     public void printOne()
    17     {
    18         printer.printOne();
    19     }
    20     
    21     public static void printStaticInfo(String s)
    22     {
    23         System.out.println(s);
    24     }
    25 }

    TestPrinter.java
     1 public class TestPrinter {
     2 
     3     private static TestClass tc = null;
     4     
     5       static
     6       {
     7           printStaticInfo("initialize test class in static");
     8           tc = new TestClass();
     9       }
    10 
    11     public TestPrinter()
    12     {
    13         System.out.println("to construct a TestPrinter object");
    14     }
    15           
    16     public void printOne()
    17     {
    18         System.out.println("One");
    19         System.out.println("compile again!");
    20     }
    21     
    22     public static void printStaticInfo(String s)
    23     {
    24         System.out.println(s);
    25     }
    26 }


         他的問題是:如果我new一個TestClass對象,然后調用testClass.printOne(),結果是什么? 會不會造成遞歸調用?

        當然不會,因為代碼中的所謂的遞歸都是在static域中的,而static域中的內容只是在這個類裝載的時候調用,也就是說它的調用在constructor之前完成,而且在整個JVM運行期間,static域中的內容只會被執行一次。當然如果這個類在運行期間被GC從PermGen中unload的話,下次該類被裝載的時候,static域中的內容將被重新調用。

         大家可以想想上面的測試輸出結果是什么,不要看下面的答案哦

    initialize test printer in static
    initialize test class in static
    to construct a TestClass object
    to construct a TestPrinter object
    to construct a TestClass object
    One
    compile again!

            關于static域是在裝載期間還是在對象初始化期間被執行,我們可以通過下面的代碼測試:

     1 public class LoaderTest {
     2     
     3     //to evaluate follow codes is invoked during class loading or object initialized
     4     //class laoding: Class.forName();
     5     //object initialized: Object obj = new ClassName();
     6     static
     7     {
     8         int i = 0;
     9         System.out.println("i is initialized in static during class loading");
    10     }
    11 }

            我們可以找個jsp,在其中加上如下內容:
    1   try
    2   {
    3         Class.forName("LoaderTest");
    4   }catch(ClassNotFoundException e)
    5   {
    6   }
        
            好了,上面代碼中我們并沒有去實例化LoaderTest對象,而只是動態裝載這個類,static的內容就被輸出了。
    posted on 2008-09-26 12:38 走走停停又三年 閱讀(2360) 評論(3)  編輯  收藏 所屬分類: Java Technology

    FeedBack:
    # re: 關于Java中的遞歸調用
    2008-09-27 10:44 | YYX
    static塊可以說是Class對象的構造函數  回復  更多評論
      
    # re: 關于Java中的遞歸調用
    2008-09-28 15:26 | zhuxing
    關于初始化有兩個概念:類型初始化和實例初始化^_^  回復  更多評論
      
    # re: 關于Java中的遞歸調用
    2013-08-14 22:38 | maco
    遞歸有沒在詳細的解釋呢  回復  更多評論
      
    主站蜘蛛池模板: 亚洲国产精品无码久久一线| 国产在线ts人妖免费视频| 亚洲精品制服丝袜四区| 免费国产在线精品一区| 内射无码专区久久亚洲| 一级毛片一级毛片免费毛片| 亚洲av中文无码| 91精品成人免费国产| 亚洲乳大丰满中文字幕| 搡女人免费免费视频观看| 久久精品国产亚洲AV麻豆不卡| 999任你躁在线精品免费不卡| 久久精品国产亚洲AV电影| 国产成人精品免费视| 亚洲熟妇无码av另类vr影视| 又爽又黄无遮挡高清免费视频| 一级一黄在线观看视频免费| 亚洲色欲一区二区三区在线观看| 久久国产精品免费视频| 亚洲一级毛片免费观看| 在线观看91精品国产不卡免费| 一个人看的免费观看日本视频www 一个人看的免费视频www在线高清动漫 | 亚洲精品国产摄像头| 四虎国产精品免费久久影院| 国产免费久久精品丫丫| 亚洲高清在线观看| 成人免费a级毛片| 一区二区三区免费视频观看| 777亚洲精品乱码久久久久久| 毛片a级毛片免费观看免下载 | 最近中文字幕大全免费版在线| 中文字幕亚洲综合久久2| 免费观看的av毛片的网站| 一个人看的免费观看日本视频www 一个人看的免费视频www在线高清动漫 | 美女被免费网站在线视频免费 | 亚洲国产a级视频| 99久久国产免费-99久久国产免费| 亚洲区日韩精品中文字幕| 国产亚洲精品无码拍拍拍色欲| 67194熟妇在线永久免费观看| 污污免费在线观看|