• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • JDK 1.5編譯中的一個奇怪問題

    發表于:2007-04-27來源:作者:點擊數: 標簽:問題1.5奇怪JDK一個
    學員馮偉立今天中午問了我一個有趣的Java編譯問題,我也無法給他解釋,不知道有沒有路過的高人能夠解釋清楚原因,望不吝賜教! 下面程序的main方法中的第二行代碼和注釋中的兩行代碼表達的意思完全相同,注釋中的兩行代碼不能通過編譯(這很容易理解),而第
      學員馮偉立今天中午問了我一個有趣的Java編譯問題,我也無法給他解釋,不知道有沒有路過的高人能夠解釋清楚原因,望不吝賜教!

      下面程序的main方法中的第二行代碼和注釋中的兩行代碼表達的意思完全相同,注釋中的兩行代碼不能通過編譯(這很容易理解),而第二行(采用方法調用鏈)卻可以順利通過編譯(這就很難理解了)。

    public class Test
    {
     public void func()
     {
      System.out.println("func");
     }

     public static void main(String args[]) throws Exception
     {
      Object obj = new Test();
      //下面這行可以成功編譯
      ((Test)obj).getClass().newInstance().func();

      //下面這兩行無法通過編譯
      /*Class c = ((Test)obj).getClass();
      c.newInstance().func(); */
     }
    }

      感謝paulex先生的幫助,在paulex先生的提示下,我基本上明白了上述問題的原因。下面是paulex先生的解答:

      因為Generic, 編譯器可以在編譯期獲得類型信息所以可以編譯這類代碼。你將下面那兩行改成

    Class<? extends Test> c = ((Test)obj).getClass();
    c.newInstance().func();

      應該就能通過編譯了。

      下面是我在paulex先生解答的基礎上,對問題的進一步解釋:

      在JDK 1.5中引入范型后,Object.getClass()方法的定義如下:

    public final Class<? extends Object> getClass()
    Returns the runtime class of an object. That Class object is the object that is locked by static synchronized methods of the represented class.

    Returns:
    The java.lang.Class object that represents the runtime class of the object. The result is of type Class<? extends X> where X is the erasure of the static type of the expression on which getClass is called.

      這說明((Test)obj).getClass()語句返回的對象類型為Class<? extends Test>,而Class<T>的newInstance()方法的定義如下:

    public T newInstance() throws InstantiationException,IllegalAccessException

      即對于編譯器看來,Class<Test>的newInstance()方法的對象類型為Test,而((Test)obj).getClass()返回的為對象類型為Class<? extends Test>,所以,編譯器認為((Test)obj).getClass().newInstance()返回的對象類型為Test。

      下面這兩行代碼之所以無法通過編譯

    Class c = ((Test)obj).getClass();
    c.newInstance().func();

      是因為((Test)obj).getClass()返回的為對象類型為Class<? extends Test>,但是我們在第一行將結果強制轉換成了Class,然后再去調用Class的newInstance方法,而不是去調用Class<Test>的newInstance方法,編譯器當然不再認為Class的newInstance方法返回的對象為Test了。

      查看關于 JDK 的全部文檔    技術觀察: 從老虎到野馬 Java 6.0新功能觀察 

    ·Java初學者專區  ·Java高級技術
    ·Java圖像與多媒體 ·Java網絡編程
    ·Eclipse ·Hibernate
    ·Spring ·Struts
    ·Java設計模式 ·EJB開發 

    原文轉自:http://www.kjueaiud.com

    評論列表(網友評論僅供網友表達個人看法,并不表明本站同意其觀點或證實其描述)
    ...
    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>