首頁 > Java > Java面試題 > Java泛型面試題目

Java泛型面試題目

(*-*)浩
發布: 2019-12-12 15:21:52
原創
3244 人瀏覽過

Java泛型面試題目

Java中的泛型是什麼? 使用泛型的好處是什麼?

泛型是Java SE 1.5的新特性,泛型的本質是參數化類型,也就是說所操作的資料型態被指定為一個參數。

好處:                                      下對網中(建議學習:java

##家的安全問題類型》 #2、前後相容

3、泛化程式碼,程式碼可以更多的重複利用

4、效能較高,用GJ(泛型JAVA)寫的程式碼可以為java編譯器和虛擬機帶來更多的類型信息,這些信息對java程式做進一步優化提供條件。

Java的泛型是如何運作的 ? 什麼是類型擦除 ?如何運作?

1、類型檢查:在生成字節碼之前提供類型檢查

2、類型擦除:所有類型參數都用他們的限定類型替換,包括類別、變量和方法(類型擦除)

3、如果類型擦除和多態性發生了衝突時,則在子類別中產生橋方法解決

#4、如果呼叫泛型方法的返回類型被擦除,則在呼叫該方法時插入強制類型轉換

類型擦除:

所有類型參數都用他們的限定類型替換:

例如T->Object   ? extends BaseClass->BaseClass

如何運作:

泛型是透過型別擦除來實現的,編譯器在編譯時擦除了所有類型相關的信息,所以在運行時不存在任何類型相關的信息。例如 List在執行時僅用一個List來表示。

這樣做的目的,是確保能和Java 5之前的版本開發二進位類別庫進行相容。你無法在運行時存取到類型參數,因為編譯器已經把泛型類型轉換成了原始型別。

根據你對這個泛型問題的回答情況,你會得到一些後續提問,例如為什麼泛型是由類型擦除來實現的或者給你展示一些會導致編譯器出錯的錯誤泛型代碼。
你可以把List傳給一個接受List參數的方法嗎?

對任何一個不太熟悉泛型的人來說,這個Java泛型題目看起來令人疑惑,因為乍看之下String是一種Object,所以List的地方,但是事實並非如此。真這樣做的話會導致編譯錯誤。

如果你再深入考慮,你會發現Java這樣做是有意義的,因為List可以儲存任何類型的物件包括String, Integer等等,而List卻只能用來儲存String s。
List<Object> objectList;
List<String> stringList;
objectList = stringList; //compilation error incompatible types
登入後複製

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

#如果你把泛型和原始型別混合使用,例如下列程式碼,java 5的javac編譯器會產生類型未檢查的警告,例如

List<String> rawList = newArrayList()
登入後複製

注意: Hello.java使用了未檢查或稱為不安全的操作;

這種警告可以使用@SuppressWarnings(“ unchecked”)註解來屏蔽。
Java中List和原始型別List之間的差異?

#原始型別與帶參數型別之間的主要差異是,在編譯時編譯器不會對原始類型進行類型安全檢查,卻會對帶參數的類型進行檢查,透過使用Object作為類型,可以告知編譯器該方法可以接受任何類型的對象,例如String或Integer。

這題的考察點在於對泛型中原始類型的正確理解。它們之間的第二點差異是,你可以把任何帶有參數的型別傳遞給原始型別List,但卻不能把List傳遞給接受 List的方法,因為會產生編譯錯誤。
寫一段泛型程式來實作LRU快取?

#對於喜歡Java程式設計的人來說這相當於一次練習。給你個提示,LinkedHashMap可以用來實現固定大小的LRU緩存,當LRU緩存已經滿了的時候,它會把最老的鍵值對移出緩存。

LinkedHashMap提供了一個稱為removeEldestEntry()的方法,該方法會被put() 和putAll()呼叫來刪除最老的鍵值對。當然,如果你已經寫了一個可執行的JUnit測試,你也可以隨意寫你自己的實作程式碼。
Array中可以用泛型嗎?

######

这可能是Java泛型面试题中最简单的一个了,当然前提是你要知道Array事实上并不支持泛型,这也是为什么Joshua Bloch在Effective Java一书中建议使用List来代替Array,因为List可以提供编译期的类型安全保证,而Array却不能。

如何编写一个泛型方法,让它能接受泛型参数并返回泛型类型?

编写泛型方法并不困难,你需要用泛型类型来替代原始类型,比如使用T, E or K,V等被广泛认可的类型占位符。最简单的情况下,一个泛型方法可能会像这样:

public V put(K key, V value) {
return cahe.put(key,value);
}
登入後複製

C++模板和java泛型之间有何不同?

java泛型实现根植于“类型消除”这一概念。当源代码被转换为Java虚拟机字节码时,这种技术会消除参数化类型。有了Java泛型,我们可以做的事情也并没有真正改变多少;他只是让代码变得漂亮些。鉴于此,Java泛型有时也被称为“语法糖”。

这和 C++模板截然不同。在 C++中,模板本质上就是一套宏指令集,只是换了个名头,编译器会针对每种类型创建一份模板代码的副本。

由于架构设计上的差异,Java泛型和C++模板有很多不同点:

C++模板可以使用int等基本数据类型。Java则不行,必须转而使用Integer。

在Java中,可以将模板的参数类型限定为某种特定类型。

在C++中,类型参数可以实例化,但java不支持。

在Java中,类型参数不能用于静态方法(?)和变量,因为它们会被不同类型参数指定的实例共享。在C++,这些类时不同的,因此类型参数可以用于静态方法和静态变量。

在Java中,不管类型参数是什么,所有的实例变量都是同一类型。类型参数会在运行时被抹去。在C++中,类型参数不同,实例变量也不同。

以上是Java泛型面試題目的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板