學習啦 > 創(chuàng)業(yè)指南 > 職場 > 面試題 > 熱門的高級Java面試題

熱門的高級Java面試題

時間: 護托1061 分享

熱門的高級Java面試題

  可變參數(shù),斷言,垃圾回收,初始化器,令牌化,日期,日歷等等都是Java核心問題。下面就由學習啦小編為大家介紹一下熱門的高級Java面試題的文章,歡迎閱讀。

  熱門的高級Java面試題篇1

  什么是可變參數(shù)?

  斷言的用途?

  什么時候使用斷言?

  什么是垃圾回收?

  用一個例子解釋垃圾回收?

  什么時候運行垃圾回收?

  垃圾回收的最佳做法?

  什么是初始化數(shù)據(jù)塊?

  熱門的高級Java面試題篇2

  什么是初始化數(shù)據(jù)塊?

  什么是靜態(tài)初始化器?

  什么是實例初始化塊?

  什么是正則表達式?

  什么是令牌化?

  給出令牌化的例子?

  如何使用掃描器類(Scanner Class)令牌化?

  如何添加小時(hour)到一個日期對象(Date Objects)?

  如何格式化日期對象?

  Java中日歷類(Calendar Class)的用途?

  熱門的高級Java面試題篇3

  1、什么是可變參數(shù)?

  可變參數(shù)允許調(diào)用參數(shù)數(shù)量不同的方法。請看下面例子中的求和方法。此方法可以調(diào)用1個int參數(shù),或2個int參數(shù),或多個int參數(shù)。

  //int(type) followed ... (three dot's) is syntax of a variable argument. public int sum(int... numbers) { //inside the method a variable argument is similar to an array. //number can be treated as if it is declared as int[] numbers; int sum = 0; for (int number: numbers) { sum += number; } return sum; } public static void main(String[] args) { VariableArgumentExamples example = new VariableArgumentExamples(); //3 Arguments System.out.println(example.sum(1, 4, 5));//10 //4 Arguments System.out.println(example.sum(1, 4, 5, 20));//30 //0 Arguments System.out.println(example.sum());//0 }

  2、斷言的用途?

  斷言是在Java 1.4中引入的。它能讓你驗證假設(shè)。如果斷言失敗(即返回false),就會拋出AssertionError(如果啟用斷言)?;緮嘌匀缦滤尽?/p>

  private int computerSimpleInterest(int principal,float interest,int years){ assert(principal>0); return 100; }

  3、什么時候使用斷言?

  斷言不應(yīng)該用于驗證輸入數(shù)據(jù)到一個public方法或命令行參數(shù)。IllegalArgumentException會是一個更好的選擇。在public方法中,只用斷言來檢查它們根本不應(yīng)該發(fā)生的情況。

  4、什么是垃圾回收?

  垃圾回收是Java中自動內(nèi)存管理的另一種叫法。垃圾回收的目的是為程序保持盡可能多的可用堆(heap)。 JVM會刪除堆上不再需要從堆引用的對象。

  5、用一個例子解釋垃圾回收?

  比方說,下面這個方法就會從函數(shù)調(diào)用。

  void method(){ Calendar calendar = new GregorianCalendar(2000,10,30); System.out.println(calendar); }

  通過函數(shù)第一行代碼中參考變量calendar,在堆上創(chuàng)建了GregorianCalendar類的一個對象。

  函數(shù)結(jié)束執(zhí)行后,引用變量calendar不再有效。因此,在方法中沒有創(chuàng)建引用到對象。

  JVM認識到這一點,會從堆中刪除對象。這就是所謂的垃圾回收。

  6、什么時候運行垃圾回收?

  垃圾回收在JVM突發(fā)奇想和心血來潮時運行(沒有那么糟糕)。運行垃圾收集的可能情況是:

  堆可用內(nèi)存不足

  CPU空閑

  7、垃圾回收的最佳做法?

  用編程的方式,我們可以要求(記住這只是一個請求——不是一個命令)JVM通過調(diào)用System.gc()方法來運行垃圾回收。

  當內(nèi)存已滿,且堆上沒有對象可用于垃圾回收時,JVM可能會拋出OutOfMemoryException。

  對象在被垃圾回收從堆上刪除之前,會運行finalize()方法。我們建議不要用finalize()方法寫任何代碼。

  8、什么是初始化數(shù)據(jù)塊?

  初始化數(shù)據(jù)塊——當創(chuàng)建對象或加載類時運行的代碼。

  有兩種類型的初始化數(shù)據(jù)塊:

  靜態(tài)初始化器:加載類時運行的的代碼

  實例初始化器:創(chuàng)建新對象時運行的代碼

  9、什么是靜態(tài)初始化器?

  請看下面的例子:static{ 和 }之間的代碼被稱為靜態(tài)初始化器。它只有在第一次加載類時運行。只有靜態(tài)變量才可以在靜態(tài)初始化器中進行訪問。雖然創(chuàng)建了三個實例,但靜態(tài)初始化器只運行一次。

  public class InitializerExamples { static int count; int i; static{ //This is a static initializers. Run only when Class is first loaded. //Only static variables can be accessed System.out.println("Static Initializer"); //i = 6;//COMPILER ERROR System.out.println("Count when Static Initializer is run is " + count); } public static void main(String[] args) { InitializerExamples example = new InitializerExamples(); InitializerExamples example2 = new InitializerExamples(); InitializerExamples example3 = new InitializerExamples(); } }

  示例輸出

  Static Initializer Count when Static Initializer is run is 0.

  10、什么是實例初始化塊?

  讓我們來看一個例子:每次創(chuàng)建類的實例時,實例初始化器中的代碼都會運行。

  public class InitializerExamples { static int count; int i; { //This is an instance initializers. Run every time an object is created. //static and instance variables can be accessed System.out.println("Instance Initializer"); i = 6; count = count + 1; System.out.println("Count when Instance Initializer is run is " + count); } public static void main(String[] args) { InitializerExamples example = new InitializerExamples(); InitializerExamples example1 = new InitializerExamples(); InitializerExamples example2 = new InitializerExamples(); } }

  11、示例輸出

  Instance Initializer Count when Instance Initializer is run is 1 Instance Initializer Count when Instance Initializer is run is 2 Instance Initializer Count when Instance Initializer is run is 3

3151980