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

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

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

    2014年8月21日

    veloeclipse eclipse 4.4不兼容該插件

    //vm 模板
    http://veloeclipse.googlecode.com/svn/trunk/update/
    eclipse 4.4不兼容該插件
    eclipse 4.4的vm新插件:http://plugin.tqlab.com/eclipse/velocityeditor/update/

    posted @ 2014-08-21 11:24 鍵盤動物 閱讀(343) | 評論 (0)編輯 收藏

    老版本的jdk下載

    http://www.oracle.com/technetwork/java/archive-139210.html

    posted @ 2014-08-21 09:52 鍵盤動物 閱讀(329) | 評論 (0)編輯 收藏

    2014年8月8日

    jvm之java源碼編譯機制

    javap -g  Foo.java   (-g 生成行號)
    javap -c  -s -l -verbose Foo

    posted @ 2014-08-08 19:31 鍵盤動物 閱讀(250) | 評論 (0)編輯 收藏

    java 自動裝箱與拆箱 引發的血案

    裝箱:從基本類型轉換成Object類型,稱之為裝箱;***拆箱:從Object轉換乘基本類型的操作,稱之為拆箱。 這個操作在反射過程中用的比較的多。 
    裝箱:在堆中建立一個Object實例,把你指定的值復制成去***拆箱:判別引用指向的堆中信息是否是要拆成的類型,是取出堆中值送給棧中變量,否則報異常 
    //在-128~127 之外的數 

    Integer num1 = 297; Integer num2 = 297; 
    System.out.println("num1==num2: "+(num1==num2)); 
    // 在-128~127 之內的數 
    Integer num3 = 97; Integer num4 = 97; 
    System.out.println("num3==num4: "+(num3==num4)); 打印的結果是:num1==num2: false num3==num4: true 
    很奇怪吧:這就歸結于java對于Integer與int的自動裝箱與拆箱的設計,是一種模式:叫享元模式(flyweight) 
    為了加大對簡單數字的重利用,java定義:在自動裝箱時對于值從–128到127之間的值,它們被裝箱為Integer對象后,會存在內存中被重用,始終只存在一個對象 
    而如果超過了從–128到127之間的值,被裝箱后的Integer對象并不會被重用,即相當于每次裝箱時都新建一個 Integer對象;明白了吧  
    以上的現象是由于使用了自動裝箱所引起的,如果你沒有使用自動裝箱,而是跟一般類一樣,用new來進行實例化,就會每次new就都一個新的對象; 

    posted @ 2014-08-08 15:32 鍵盤動物 閱讀(271) | 評論 (0)編輯 收藏

    Java泛型面試題


      1. Java中的泛型是什么 ? 使用泛型的好處是什么?

      這是在各種Java泛型面試中,一開場你就會被問到的問題中的一個,主要集中在初級和中級面試中。那些擁有Java1.4或更早版本的開發背景的人都知道,在集合中存儲對象并在使用前進行類型轉換是多么的不方便。泛型防止了那種情況的發生。它提供了編譯期的類型安全,確保你只能把正確類型的對象放入集合中,避免了在運行時出現ClassCastException。

      2. Java的泛型是如何工作的 ? 什么是類型擦除 ?

      這是一道更好的泛型面試題。泛型是通過類型擦除來實現的,編譯器在編譯時擦除了所有類型相關的信息,所以在運行時不存在任何類型相關的信息。例如List<String>在運行時僅用一個List來表示。這樣做的目的,是確保能和Java 5之前的版本開發二進制類庫進行兼容。你無法在運行時訪問到類型參數,因為編譯器已經把泛型類型轉換成了原始類型。根據你對這個泛型問題的回答情況,你會得到一些后續提問,比如為什么泛型是由類型擦除來實現的或者給你展示一些會導致編譯器出錯的錯誤泛型代碼。請閱讀我的Java中泛型是如何工作的來了解更多信息。

      3. 什么是泛型中的限定通配符和非限定通配符 ?

      這是另一個非常流行的Java泛型面試題。限定通配符對類型進行了限制。有兩種限定通配符,一種是<? extends T>它通過確保類型必須是T的子類來設定類型的上界,另一種是<? super T>它通過確保類型必須是T的父類來設定類型的下界。泛型類型必須用限定內的類型來進行初始化,否則會導致編譯錯誤。另一方面<?>表示了非限定通配符,因為<?>可以用任意類型來替代。更多信息請參閱我的文章泛型中限定通配符和非限定通配符之間的區別

      4. List<? extends T>和List <? super T>之間有什么區別 ?

      這和上一個面試題有聯系,有時面試官會用這個問題來評估你對泛型的理解,而不是直接問你什么是限定通配符和非限定通配符。這兩個List的聲明都是限定通配符的例子,List<? extends T>可以接受任何繼承自T的類型的List,而List<? super T>可以接受任何T的父類構成的List。例如List<? extends Number>可以接受List<Integer>或List<Float>。在本段出現的連接中可以找到更多信息。

      5. 如何編寫一個泛型方法,讓它能接受泛型參數并返回泛型類型?

      編寫泛型方法并不困難,你需要用泛型類型來替代原始類型,比如使用T, E or K,V等被廣泛認可的類型占位符。泛型方法的例子請參閱Java集合類框架。最簡單的情況下,一個泛型方法可能會像這樣:

    public V put(K key, V value) {         return cache.put(key, value); } 

      6. Java中如何使用泛型編寫帶有參數的類?

      這是上一道面試題的延伸。面試官可能會要求你用泛型編寫一個類型安全的類,而不是編寫一個泛型方法。關鍵仍然是使用泛型類型來代替原始類型,而且要使用JDK中采用的標準占位符。

      7. 編寫一段泛型程序來實現LRU緩存?

      對于喜歡Java編程的人來說這相當于是一次練習。給你個提示,LinkedHashMap可以用來實現固定大小的LRU緩存,當LRU緩存已經滿了的時候,它會把最老的鍵值對移出緩存。LinkedHashMap提供了一個稱為removeEldestEntry()的方法,該方法會被put()和putAll()調用來刪除最老的鍵值對。當然,如果你已經編寫了一個可運行的JUnit測試,你也可以隨意編寫你自己的實現代碼。

      8. 你可以把List<String>傳遞給一個接受List<Object>參數的方法嗎?

      對任何一個不太熟悉泛型的人來說,這個Java泛型題目看起來令人疑惑,因為乍看起來String是一種Object,所以List<String>應當可以用在需要List<Object>的地方,但是事實并非如此。真這樣做的話會導致編譯錯誤。如果你再深一步考慮,你會發現Java這樣做是有意義的,因為List<Object>可以存儲任何類型的對象包括String, Integer等等,而List<String>卻只能用來存儲Strings。

    List<Object> objectList; List<String> stringList;       objectList = stringList;  //compilation error incompatible types

      9. Array中可以用泛型嗎?

      這可能是Java泛型面試題中最簡單的一個了,當然前提是你要知道Array事實上并不支持泛型,這也是為什么Joshua Bloch在Effective Java一書中建議使用List來代替Array,因為List可以提供編譯期的類型安全保證,而Array卻不能。

      10. 如何阻止Java中的類型未檢查的警告?

      如果你把泛型和原始類型混合起來使用,例如下列代碼,Java 5的javac編譯器會產生類型未檢查的警告,例如

    List<String> rawList = new ArrayList() 注意: Hello.java使用了未檢查或稱為不安全的操作; 

      這種警告可以使用@SuppressWarnings("unchecked")注解來屏蔽。

      Java泛型面試題補充更新:

      我手頭又拿到了幾個Java泛型面試題跟大家分享下,這幾道題集中在泛型類型和原始類型的區別上,以及我們是否可以用Object來代替限定通配符的使用等等:

      Java中List<Object>和原始類型List之間的區別?

      原始類型和帶參數類型<Object>之間的主要區別是,在編譯時編譯器不會對原始類型進行類型安全檢查,卻會對帶參數的類型進行檢查,通過使用Object作為類型,可以告知編譯器該方法可以接受任何類型的對象,比如String或Integer。這道題的考察點在于對泛型中原始類型的正確理解。它們之間的第二點區別是,你可以把任何帶參數的類型傳遞給原始類型List,但卻不能把List<String>傳遞給接受List<Object>的方法,因為會產生變異錯誤。更多詳細信息請參閱Java中的泛型是如何工作的

      Java中List<?>和List<Object>之間的區別是什么?

      這道題跟上一道題看起來很像,實質上卻完全不同。List<?> 是一個未知類型的List,而List<Object>其實是任意類型的List。你可以把List<String>, List<Integer>賦值給List<?>,卻不能把List<String>賦值給List<Object>。     

    List<?> listOfAnyType; List<Object> listOfObject = new ArrayList<Object>(); List<String> listOfString = new ArrayList<String>(); List<Integer> listOfInteger = new ArrayList<Integer>();       listOfAnyType = listOfString; //legal listOfAnyType = listOfInteger; //legal listOfObjectType = (List<Object>) listOfString; //compiler error - in-convertible types 

      想了解更多關于通配符的信息請查看Java中的泛型通配符示例

      List<String>和原始類型List之間的區別.

      該題類似于“原始類型和帶參數類型之間有什么區別”。帶參數類型是類型安全的,而且其類型安全是由編譯器保證的,但原始類型List卻不是類型安全的。你不能把String之外的任何其它類型的Object存入String類型的List中,而你可以把任何類型的對象存入原始List中。使用泛型的帶參數類型你不需要進行類型轉換,但是對于原始類型,你則需要進行顯式的類型轉換。

    List listOfRawTypes = new ArrayList(); listOfRawTypes.add("abc"); listOfRawTypes.add(123); //編譯器允許這樣 - 運行時卻會出現異常 String item = (String) listOfRawTypes.get(0); //需要顯式的類型轉換 item = (String) listOfRawTypes.get(1); //拋ClassCastException,因為Integer不能被轉換為String       List<String> listOfString = new ArrayList(); listOfString.add("abcd"); listOfString.add(1234); //編譯錯誤,比在運行時拋異常要好 item = listOfString.get(0); //不需要顯式的類型轉換 - 編譯器自動轉換 

    posted @ 2014-08-08 15:14 鍵盤動物 閱讀(543) | 評論 (0)編輯 收藏

    泛型的好處

    Java 語言中引入泛型是一個較大的功能增強。不僅語言、類型系統和編譯器有了較大的變化,以支持泛型,而且類庫也進行了大翻修,所以許多重要的類,比如集合框架,都已經成為泛型化的了。

    這帶來了很多好處:

    1,類型安全。 泛型的主要目標是提高 Java 程序的類型安全。通過知道使用泛型定義的變量的類型限制,編譯器可以在一個高得多的程度上驗證類型假設。沒有泛型,這些假設就只存在于程序員的頭腦中(或者如果幸運的話,還存在于代碼注釋中)。

     

    2,消除強制類型轉換。 泛型的一個附帶好處是,消除源代碼中的許多強制類型轉換。這使得代碼更加可讀,并且減少了出錯機會。

     

    3,潛在的性能收益。 泛型為較大的優化帶來可能。在泛型的初始實現中,編譯器將強制類型轉換(沒有泛型的話,程序員會指定這些強制類型轉換)插入生成的字節碼中。但是更多類型信息可用于編譯器這一事實,為未來版本的 JVM 的優化帶來可能。由于泛型的實現方式,支持泛型(幾乎)不需要 JVM 或類文件更改。所有工作都在編譯器中完成,編譯器生成類似于沒有泛型(和強制類型轉換)時所寫的代碼,只是更能確保類型安全而已。

     

     

     Java語言引入泛型的好處是安全簡單。泛型的好處是在編譯的時候檢查類型安全,并且所有的強制轉換都是自動和隱式的,提高代碼的重用率。

        泛型在使用中還有一些規則和限制:
        1、泛型的類型參數只能是類類型(包括自定義類),不能是簡單類型。
        2、同一種泛型可以對應多個版本(因為參數類型是不確定的),不同版本的泛型類實例是不兼容的。
        3、泛型的類型參數可以有多個。
        4、泛型的參數類型可以使用extends語句,例如<T extends superclass>。習慣上成為“有界類型”。
        5、泛型的參數類型還可以是通配符類型。例如Class<?> classType = Class.forName(Java.lang.String);

    posted @ 2014-08-08 14:57 鍵盤動物 閱讀(294) | 評論 (0)編輯 收藏

    java 重寫和重載的規則

    重寫方法的規則

    1、參數列表必須完全與被重寫的方法相同,否則不能稱其為重寫而是重載。

    2、返回的類型必須一直與被重寫的方法的返回類型相同,否則不能稱其為重寫而是重載。

    3、訪問修飾符的限制一定要大于被重寫方法的訪問修飾符(public>protected>default>private)

    4、重寫方法一定不能拋出新的檢查異常或者比被重寫方法申明更加寬泛的檢查型異常。例如:

    父類的一個方法申明了一個檢查異常IOException,在重寫這個方法是就不能拋出Exception,只能拋出IOException的子類異常,可以拋出非檢查異常。

     

    而重載的規則:

    1、必須具有不同的參數列表;

    2、可以有不責罵的返回類型,只要參數列表不同就可以了;

    3、可以有不同的訪問修飾符;

    4、可以拋出不同的異常;

     

    重寫與重載的區別在于:

    重寫多態性起作用,對調用被重載過的方法可以大大減少代碼的輸入量,同一個方法名只要往里面傳遞不同的參數就可以擁有不同的功能或返回值。

    用好重寫和重載可以設計一個結構清晰而簡潔的類,可以說重寫和重載在編寫代碼過程中的作用非同一般.

    posted @ 2014-08-08 14:44 鍵盤動物 閱讀(309) | 評論 (0)編輯 收藏

    java 泛型使用 擦除法

    擦除法并不代表編譯后的字節碼中就不包含我們在源代碼定義的泛型類型了。而是在字節碼中引入新屬性Signature 和 LocalVariableTypeTable 來存儲泛型。這也是為什么可以通過返回值重載,及通過反射獲取到泛型的根本原因

    posted @ 2014-08-08 14:38 鍵盤動物 閱讀(210) | 評論 (0)編輯 收藏

    2014年8月7日

    Collections.synchronizedMap(new HashMap())這個方法是什么意思

    Collections.synchronizedMap是個比較老的API了,實際用起來還要手工做一些事。

    建議樓主用Java5的ConcurrentHashMap或Java6的ConcurrentSkipListMap

    posted @ 2014-08-07 16:40 鍵盤動物 閱讀(513) | 評論 (0)編輯 收藏

    2014年7月31日

    Eclipse中關聯jar出現亂碼

    1、首先要清楚源碼的編碼方式是什么?

    如果源碼的編碼是utf-8 就需要這樣修改

    Preferences General > Workspace 修改Text file encoding

    為UTF-8后才行。

    重新啟動Eclipse就可以解決了()

    posted @ 2014-07-31 15:31 鍵盤動物 閱讀(187) | 評論 (0)編輯 收藏

    僅列出標題  下一頁
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    導航

    統計

    常用鏈接

    留言簿

    隨筆檔案

    新聞分類

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 欧美a级成人网站免费| 亚洲AV无码久久精品色欲| 亚洲一区免费视频| 国产午夜精品理论片免费观看 | 无码日韩人妻AV一区免费l| 91网站免费观看| 亚洲国产精品成人精品无码区| 自拍偷自拍亚洲精品偷一| 国产福利视精品永久免费| 亚洲国产精品无码久久一线| 黄页免费视频播放在线播放| 成年丰满熟妇午夜免费视频| 亚洲精品视频免费看| 西西人体免费视频| 亚洲乱码日产精品a级毛片久久| 亚洲欧美不卡高清在线| 成人免费在线看片| 日韩亚洲AV无码一区二区不卡| 国产A∨免费精品视频| 免费大黄网站在线看| 亚洲一线产品二线产品| 69堂人成无码免费视频果冻传媒| 亚洲成Av人片乱码色午夜| 国产日韩在线视频免费播放| 亚洲电影日韩精品 | h视频在线观看免费| 国产三级免费电影| 亚洲成AV人片高潮喷水| 亚洲性线免费观看视频成熟 | 成人精品国产亚洲欧洲| 在线观看免费宅男视频| 亚洲国产日韩视频观看| 青青视频观看免费99| 亚洲沟沟美女亚洲沟沟| 99爱在线观看免费完整版| 久久亚洲精品中文字幕无码| 热久久这里是精品6免费观看| 久久久久亚洲爆乳少妇无| 一二三区免费视频| av在线亚洲欧洲日产一区二区| 人成免费在线视频|