日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

java程序语言228_2019年Java面试题基础系列228道(5)

發布時間:2024/7/5 217 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java程序语言228_2019年Java面试题基础系列228道(5) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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 會出現編譯錯誤,但是

bytea =127;byteb =127;b =a +b;// error : cannot convert from int to byteb +=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 的區別?

35、WeakHashMap 是怎么工作的?

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

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

到 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 課保證遍歷順序是元素插入的順序。

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 課保證遍歷順序是元素插入的順序。

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的java程序语言228_2019年Java面试题基础系列228道(5)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。