歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Java面試題之Java基礎部分

Java面試題之Java基礎部分

日期:2017/3/1 9:43:42   编辑:Linux編程

1、一個".java"源文件中是否可以包括多個類(不是內部類)?有什麼限制?

  可以有多個類,但只能有一個public的類,並且public的類名必須與文件名相一致。

2、Java有沒有goto?

java中的保留字,現在沒有在java中使用。

  

3、說說&和&&的區別。

(1)&&可以用作邏輯與的運算符;&既可以用作邏輯與的運算符,也可以用作位運算符;(2)&和&&都作為邏輯與運算符時,&&具有短路的功能,即如果第一個表達式為false,則不再計算第二個表達式,而&則不會。

4、在JAVA中如何跳出當前的多重嵌套循環?

  在Java中,要想跳出多重循環,可以在外面的循環語句前定義一個標號,然後在裡層循環體的代碼中使用帶有標號的break 語句,即可跳出外層循環。例如,

  ok:

   for(int i=0;i<10;i++)

   {

   for(int j=0;j<10;j++)

   {

   System.out.println(“i=” + i + “,j=” + j);

   if(j == 5) break ok;

   }

   }

  另外,我個人通常並不使用標號這種方式,而是讓外層的循環條件表達式的結果可以受到裡層循環體代碼的控制,例如,要在二維數組中查找到某個數字。

  int arr[][] = {{1,2,3},{4,5,6,7},{9}};

  boolean found = false;

  for(int i=0;i<arr.length && !found;i++)

   {

   for(int j=0;j<arr[i].length;j++)

   {

   System.out.println(“i=” + i + “,j=” + j);

   if(arr[i][j] == 5)

   {

   found = true;

break;

   }

   }

   }

5、switch語句能否作用在byte上,能否作用在long上,能否作用在String上?

  在switch(expr1)中,expr1只能是一個整數表達式或者枚舉常量(更大字體),整數表達式可以是int基本類型或Integer包裝類型,由於,byte,short,char都可以隱含轉換為int,所以,這些類型以及這些類型的包裝類型也是可以的。顯然,long和String類型都不符合switch的語法規定,並且不能被隱式轉換成int類型,所以,它們不能作用於swtich語句中。

6、short s1 = 1; s1 = s1 + 1;有什麼錯? short s1 = 1; s1 += 1;有什麼錯?

  對於short s1 = 1; s1 = s1 + 1; 由於s1+1運算時會自動提升表達式的類型,所以結果是int型,再賦值給short類型s1時,編譯器將報告需要強制轉換類型的錯誤。

對於short s1 = 1; s1 += 1;由於 += 是java語言規定的運算符,java編譯器會對它進行特殊處理,因此可以正確編譯。

7、char型變量中能不能存貯一個中文漢字?為什麼?

  char型變量是用來存儲Unicode編碼的字符的,unicode編碼字符集中包含了漢字,所以,char型變量中當然可以存儲漢字啦。不過,如果某個特殊的漢字沒有被包含在unicode編碼字符集中,那麼,這個char型變量中就不能存儲這個特殊漢字。補充說明:unicode編碼占用兩個字節,所以,char類型的變量也是占用兩個字節。

  

8、用最有效率的方法算出2乘以8等於幾?

  2 << 3,

因為將一個數左移n位,就相當於乘以了2的n次方,那麼,一個數乘以8只要將其左移3位即可,而位運算cpu直接支持的,效率最高,所以,2乘��8等於幾的最效率的方法是2 << 3。

9、請設計一個一百億的計算器

具體實現代碼:http://blog.csdn.net/xiaofeilong321/article/details/22894137

  首先要明白這道題目的考查點是什麼,一是大家首先要對計算機原理的底層細節要清楚、要知道加減法的位運算原理和知道計算機中的算術運算會發生越界的情況,二是要具備一定的面向對象的設計思想。

  首先,計算機中用固定數量的幾個字節來存儲的數值,所以計算機中能夠表示的數值是有一定的范圍的,為了便於講解和理解,我們先以byte 類型的整數為例,它用1個字節進行存儲,表示的最大數值范圍為-128到+127。-1在內存中對應的二進制數據為11111111,如果兩個-1相加,不考慮Java運算時的類型提升,運算後會產生進位,二進制結果為1,11111110,由於進位後超過了byte類型的存儲空間,所以進位部分被捨棄,即最終的結果為11111110,也就是-2,這正好利用溢位的方式實現了負數的運算。-128在內存中對應的二進制數據為10000000,如果兩個-128相加,不考慮Java運算時的類型提升,運算後會產生進位,二進制結果為1,00000000,由於進位後超過了byte類型的存儲空間,所以進位部分被捨棄,即最終的結果為00000000,也就是0,這樣的結果顯然不是我們期望的,這說明計算機中的算術運算是會發生越界情況的,兩個數值的運算結果不能超過計算機中的該類型的數值范圍。由於Java中涉及表達式運算時的類型自動提升,我們無法用byte類型來做演示這種問題和現象的實驗,大家可以用下面一個使用整數做實驗的例子程序體驗一下:

   int a = Integer.MAX_VALUE;

   int b = Integer.MAX_VALUE;

   int sum = a + b;

   System.out.println(“a=”+a+”,b=”+b+”,sum=”+sum);

  

  先不考慮long類型,由於int的正數范圍為2的31次方,表示的最大數值約等於2*1000*1000*1000,也就是20億的大小,所以,要實現一個一百億的計算器,我們得自己設計一個類可以用於表示很大的整數,並且提供了與另外一個整數進行加減乘除的功能,大概功能如下:

  ()這個類內部有兩個成員變量,一個表示符號,另一個用字節數組表示數值的二進制數

  ()有一個構造方法,把一個包含有多位數值的字符串轉換到內部的符號和字節數組中

  ()提供加減乘除的功能

  public class BigInteger

  {

   int sign;

   byte[] val;

   public Biginteger(String val)

   {

   sign = ;

   val = ;

   }

   public BigInteger add(BigInteger other)

   {

  

   }

   public BigInteger subtract(BigInteger other)

   {

  

   }

   public BigInteger multiply(BigInteger other)

   {

  

   }

   public BigInteger divide(BigInteger other)

   {

  

   }

  

  }

  備注:要想寫出這個類的完整代碼,是非常復雜的,如果有興趣的話,可以參看jdk中自帶的java.math.BigInteger類的源碼。面試的人也知道誰都不可能在短時間內寫出這個類的完整代碼的,他要的是你是否有這方面的概念和意識,他最重要的還是考查你的能力,所以,你不要因為自己無法寫出完整的最終結果就放棄答這道題,你要做的就是你比別人寫得多,證明你比別人強,你有這方面的思想意識就可以了,畢竟別人可能連題目的意思都看不懂,什麼都沒寫,你要敢於答這道題,即使只答了一部分,那也與那些什麼都不懂的人區別出來,拉開了距離,算是矮子中的高個,機會當然就屬於你了。另外,答案中的框架代碼也很重要,體現了一些面向對象設計的功底,特別是其中的方法命名很專業,用的英文單詞很精准,這也是能力、經驗、專業性、英語水平等多個方面的體現,會給人留下很好的印象,在編程能力和其他方面條件差不多的情況下,英語好除了可以使你獲得更多機會外,薪水可以高出一千元。

  

10、使用final關鍵字修飾一個變量時,是引用不能變,還是引用的對象不能變?

  使用final關鍵字修飾一個變量時,是指引用變量不能變,引用變量所指向的對象中的內容還是可以改變的。例如,對於如下語句:

   final StringBuffer a=new StringBuffer("immutable");

執行如下語句將報告編譯期錯誤:

  a=new StringBuffer("");

但是,執行如下語句則可以通過編譯:

  a.append(" broken!");

  有人在定義方法的參數時,可能想采用如下形式來阻止方法內部修改傳進來的參數對象:public void method(final StringBuffer param)

  {... .... ....}

  實際上,這是辦不到的,在該方法內部仍然可以增加如下代碼來修改參數對象:

   param.append("a");

Java 8 中 HashMap 的性能提升 http://www.linuxidc.com/Linux/2014-04/100868.htm

Java 8 的 Nashorn 引擎 http://www.linuxidc.com/Linux/2014-03/98880.htm

Java 8簡明教程 http://www.linuxidc.com/Linux/2014-03/98754.htm

更多詳情見請繼續閱讀下一頁的精彩內容: http://www.linuxidc.com/Linux/2014-06/102555p2.htm

Copyright © Linux教程網 All Rights Reserved