高級Java面試題及答案2016

高級Java面試題及答案2016

日期:2023-02-24 07:48:13    编辑:网络投稿    来源:互联网

高級Java面試題及答案2016  java高級面試有哪些常見問題呢?下面yjbys為大家分享最新java常見面試題及答案解析,僅供參考!  什么是可變參數?  可變參數允許調用參數數量

高級Java面試題及答案2016

  java高級面試有哪些常見問題呢?下面yjbys為大家分享最新java常見面試題及答案解析,僅供參考!

  什么是可變參數?

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

  //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

  }

  斷言的用途?

  斷言是在Java 1.4中引入的。它能讓你驗證假設。如果斷言失敗(即返回false),就會拋出AssertionError(如果啟用斷言)。基本斷言如下所示。

  private int computerSimpleInterest(int principal,float interest,int years){

  assert(principal>0);

  return 100;

  }

  什么時候使用斷言?

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

  什么是垃圾回收?

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

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

  比方說,下面這個方法就會從函數調用。

  void method(){

  Calendar calendar = new GregorianCalendar(2000,10,30);

  System.out.println(calendar);

  }

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

  函數結束執行后,引用變量calendar不再有效。因此,在方法中沒有創建引用到對象。

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

  什么時候運行垃圾回收?

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

  堆可用內存不足

  CPU空閑

  垃圾回收的最佳做法?

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

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

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

  什么是初始化數據塊?

  初始化數據塊——當創建對象或加載類時運行的代碼。

  有兩種類型的`初始化數據塊:

  靜態初始化器:加載類時運行的的代碼

  實例初始化器:創建新對象時運行的代碼

  什么是靜態初始化器?

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

  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 whenStaticInitializer is run is0.

  什么是實例初始化塊?

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

  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);

  } 共3頁: 上一頁123下一頁