2020年Java面試題基礎系列二(21~50題)

21、存在兩個類,B 繼承 A,C 繼承 B,我們能將 B 轉換爲C 麼?如 C = (C) B;

這屬於強制類型轉換,如果被轉換的B實例不是C類型,會有異常

比如你的ABC分別對應動物,貓,黑貓。

向上轉型就是比如

C c = new C();

B b = c;

你把c轉型爲B,黑貓是貓嗎?是啊,所以這是ok的。

但是反過來

B b = new B();

C c = (C)b;

這就不ok了,只知道這個b是一隻貓,他不一定是黑貓。

但如果這個b已經確定是一隻黑貓了,那就可以轉型了

B b = new C();

C c = (C)b;

這裏的b本來就是黑貓啊。

22、哪個類包含 clone 方法?是 Cloneable 還是 Object?

java.lang.Cloneable 是一個標示性接口,不包含任何方法,clone 方法在object 類中定義。並且需要知道 clone() 方法是一個本地方法,這意味着它是由c 或 c++ 或 其他本地語言實現的。

23、Java 中 ++ 操作符是線程安全的嗎?

不是線程安全的操作。它涉及到多個指令,如讀取變量值,增加,然後存儲回內存,這個過程可能會出現多個線程交差。

24、a = a + b 與 a += b 的區別

+= 隱式的將加操作的結果類型強制轉換爲持有結果的類型。如果兩這個整型相加,如 byte、short 或者 int,首先會將它們提升到 int 類型,然後在執行加法操作。如果加法操作的結果比 a 的最大值要大,則 a+b 會出現編譯錯誤,但是

byte a = 127;
byte b = 127;
b = a + b;
// error : cannot convert from int to byte
b += a;
// ok複製代碼

(譯者注:這個地方應該表述的有誤,其實無論 a+b 的值爲多少,編譯器都會報錯,因爲 a+b 操作會將 a、b 提升爲 int 類型,所以將 int 類型賦值給 byte就會編譯出錯)

25、我能在不進行強制轉換的情況下將一個 double 值賦值給long 類型的變量嗎?

不行,你不能在沒有強制類型轉換的前提下將一個 double 值賦值給 long 類型的變量,因爲 double 類型的範圍比 long 類型更廣,所以必須要進行強制轉換。

26、3*0.1 == 0.3 將會返回什麼?true 還是 false?

false,因爲有些浮點數不能完全精確的表示出來。

27、int 和 Integer 哪個會佔用更多的內存?

Integer 對象會佔用更多的內存。Integer 是一個對象,需要存儲對象的元數據。但是 int 是一個原始類型的數據,所以佔用的空間更少。

28、爲什麼 Java 中的 String 是不可變的(Immutable)?

Java 中的 String 不可變是因爲 Java 的設計者認爲字符串使用非常頻繁,將字符串設置爲不可變可以允許多個客戶端之間共享相同的字符串。

29、我們能在 Switch 中使用 String 嗎?

從 Java 7 開始,我們可以在 switch case 中使用字符串,但這僅僅是一個語法糖。內部實現在 switch 中使用字符串的 hash code。

30、Java 中的構造器鏈是什麼?

當你從一個構造器中調用另一個構造器,就是 Java 中的構造器鏈。這種情況只在重載了類的構造器的時候纔會出現。

31、64 位 JVM 中,int 的長度是多數?

Java 中,int 類型變量的長度是一個固定值,與平臺無關,都是 32 位。意思就是說,在32位和64位的java虛擬機中,int 類型的長度是相同的。

32、Serial 與 Parallel GC 之間的不同之處?

Serial 與 Parallel 在 GC 執行的時候都會引起 stop-the-world。它們之間主要不同 serial 收集器是默認的複製收集器,執行 GC 的時候只有一個線程,而parallel 收集器使用多個 GC 線程來執行。

33、32 位和 64 位的 JVM,int 類型變量的長度是多數?

32 位和 64 位的 JVM 中,int 類型變量的長度是相同的,都是 32 位或者 4個字節。

34、Java 中 WeakReference 與 SoftReference 的區別?

雖然 WeakReference 與 SoftReference 都有利於提高 GC 和 內存的效率,但是 WeakReference ,一旦失去最後一個強引用,就會被 GC 回收,而軟引用雖然不能阻止被回收,但是可以延遲到 JVM 內存不足的時候。

35、WeakHashMap 是怎麼工作的?

WeakHashMap 的工作與正常的 HashMap 類似,但是使用弱引用作爲 key,意思就是當 key 對象沒有任何引用時,key/value 將會被回收。

36、JVM 選項 -XX:+UseCompressedOops 有什麼作用?爲什麼要使用?

當你將你的應用從 32 位的 JVM 遷移到 64 位的 JVM 時,由於對象的指針從32 位增加到了 64 位,因此堆內存會突然增加,差不多要翻倍。這也會對 CPU緩存(容量比內存小很多)的數據產生不利的影響。因爲,遷移到 64 位的 JVM主要動機在於可以指定最大堆大小,通過壓縮 OOP 可以節省一定的內存。通過-XX:+UseCompressedOops 選項,JVM 會使用 32 位的 OOP,而不是 64 位的 OOP。

37、怎樣通過 Java 程序來判斷 JVM 是 32 位 還是 64位?

你可以檢查某些系統屬性如 sun.arch.data.model 或 os.arch 來獲取該信息。

38、32 位 JVM 和 64 位 JVM 的最大堆內存分別是多數?

理論上說上 32 位的 JVM 堆內存可以到達 2^32,即 4GB,但實際上會比這個小很多。不同操作系統之間不同,如 Windows 系統大約 1.5 GB,Solaris 大約3GB。64 位 JVM 允許指定最大的堆內存,理論上可以達到 2^64,這是一個非常大的數字,實際上你可以指定堆內存大小到 100GB。甚至有的 JVM,如 Azul,堆內存到 1000G 都是可能的。

39、JRE、JDK、JVM 及 JIT 之間有什麼不同?

JRE 代表 Java 運行 時(Java run-time),是 運 行 Java 引用所必須的。JDK 代表 Java 開發工具(Java development kit),是 Java 程序的開發工具,如 Java編譯器,它也包含 JRE。JVM 代表 Java 虛擬機(Java virtual machine),它的責任是運行 Java 應用。JIT 代表即時編譯(Just In Time compilation),當代碼執行的次數超過一定的閾值時,會將 Java 字節碼轉換爲本地代碼,如,主要的熱點代碼會被準換爲本地代碼,這樣有利大幅度提高 Java 應用的性能。

40、解釋 Java 堆空間及 GC?

當通過 Java 命令啓動 Java 進程的時候,會爲它分配內存。內存的一部分用於創建堆空間,當程序中創建對象的時候,就從對空間中分配內存。GC 是 JVM 內部的一個進程,回收無效對象的內存用於將來的分配。

41、你能保證 GC 執行嗎?

不能,雖然你可以調用 System.gc() 或者 Runtime.gc(),但是沒有辦法保證 GC的執行。

42、怎麼獲取 Java 程序使用的內存?堆使用的百分比?

可以通過 java.lang.Runtime 類中與內存相關方法來獲取剩餘的內存,總內存及最大堆內存。通過這些方法你也可以獲取到堆使用的百分比及堆內存的剩餘空間。Runtime.freeMemory() 方法返回剩餘空間的字節數,Runtime.totalMemory()方法總內存的字節數,Runtime.maxMemory() 返回最大內存的字節數。

43、Java 中堆和棧有什麼區別?

JVM 中堆和棧屬於不同的內存區域,使用目的也不同。棧常用於保存方法幀和局部變量,而對象總是在堆上分配。棧通常都比堆小,也不會在多個線程之間共享,而堆被整個 JVM 的所有線程共享。

44、“a==b”和”a.equals(b)”有什麼區別?

如果 a 和 b 都是對象,則 a==b 是比較兩個對象的引用,只有當 a 和 b 指向的是堆中的同一個對象纔會返回 true,而 a.equals(b) 是進行邏輯比較,所以通常需要重寫該方法來提供邏輯一致性的比較。例如,String 類重寫 equals() 方法,所以可以用於兩個不同對象,但是包含的字母相同的比較。

45、a.hashCode() 有什麼用?與 a.equals(b) 有什麼關係?

hashCode() 方法是相應對象整型的 hash 值。它常用於基於 hash 的集合類,如 Hashtable、HashMap、LinkedHashMap 等等。它與 equals() 方法關係特別緊密。根據 Java 規範,兩個使用 equal() 方法來判斷相等的對象,必須具有相同的 hash code。

46、final、finalize 和 finally 的不同之處?

final 是一個修飾符,可以修飾變量、方法和類。如果 final 修飾變量,意味着該變量的值在初始化後不能被改變。finalize 方法是在對象被回收之前調用的方法,給對象自己最後一個復活的機會,但是什麼時候調用 finalize 沒有保證。finally是一個關鍵字,與 try 和 catch 一起用於異常的處理。finally 塊一定會被執行,無論在 try 塊中是否有發生異常。

47、Java 中的編譯期常量是什麼?使用它又什麼風險?

公共靜態不可變(public static final )變量也就是我們所說的編譯期常量,這裏的 public 可選的。實際上這些變量在編譯時會被替換掉,因爲編譯器知道這些變量的值,並且知道這些變量在運行時不能改變。這種方式存在的一個問題是你使用了一個內部的或第三方庫中的公有編譯時常量,但是這個值後面被其他人改變了,但是你的客戶端仍然在使用老的值,甚至你已經部署了一個新的 jar。爲了避免這種情況,當你在更新依賴 JAR 文件時,確保重新編譯你的程序。

48、List、Set、Map 和 Queue 之間的區別(答案)

List 是一個有序集合,允許元素重複。它的某些實現可以提供基於下標值的常量訪問時間,但是這不是 List 接口保證的。Set 是一個無序集合。

49、poll() 方法和 remove() 方法的區別?

poll() 和 remove() 都是從隊列中取出一個元素,但是 poll() 在獲取元素失敗的時候會返回空,但是 remove() 失敗的時候會拋出異常。

50、Java 中 LinkedHashMap 和 PriorityQueue 的區別是什麼?

PriorityQueue 保證最高或者最低優先級的的元素總是在隊列頭部,但是LinkedHashMap 維持的順序是元素插入的順序。當遍歷一個 PriorityQueue時,沒有任何順序保證,但是 LinkedHashMap 課保證遍歷順序是元素插入的順序。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章