當前位置:學識都>好好學習>考研>

職場中的JAVA筆試經驗分享

學識都 人氣:8.54K

 java筆試必備題

職場中的JAVA筆試經驗分享

  ·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編譯器會對它進行特殊處理,因此可以正確編譯。  ·用最有效率的方法算出2乘以8等於幾?  2 << 3,  因爲將一個數左移n位,就相當於乘以了2的n次方,那麼,一個數乘以8只要將其左移3位即可,而位運算cpu直接支持的,效率最高,所以,2乘以8等於幾的最效率的方法是2 << 3。  ·請設計一個一百億的計算器  首先要明白這道題目的考查點是什麼,一是大家首先要對計算機原理的底層細節要清楚、要知道加減法的位運算原理和知道計算機中的算術運算會發生越界的情況,二是要具備一定的面向對象的設計思想。  首先,計算機中用固定數量的幾個字節來存儲的數值,所以計算機中能夠表示的數值是有一定的範圍的,爲了便於講解和理解,我們先以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 = _value;  int b = _value;  int sum = a + b;  tln(“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中自帶的nteger類的源碼。面試的人也知道誰都不可能在短時間內寫出這個類的完整代碼的,他要的是你是否有這方面的概念和意識,他最重要的還是考查你的能力,所以,你不要因爲自己無法寫出完整的最終結果就放棄答這道題,你要做的就是你比別人寫得多,證明你比別人強,你有這方面的思想意識就可以了,畢竟別人可能連題目的意思都看不懂,什麼都沒寫,你要敢於答這道題,即使只答了一部分,那也與那些什麼都不懂的人區別出來,拉開了距離,算是矮子中的高個,機會當然就屬於你了。另外,答案中的框架代碼也很重要,體現了一些面向對象設計的功底,特別是其中的方法命名很專業,用的英文單詞很精準,這也是能力、經驗、專業性、英語水平等多個方面的體現,會給人留下很好的印象,在編程能力和其他方面條件差不多的情況下,英語好除了可以使你獲得更多機會外,薪水可以高出一千元。  ·使用final關鍵字修飾一個變量時,是引用不能變,還是引用的對象不能變?  使用final關鍵字修飾一個變量時,是指引用變量不能變,引用變量所指向的對象中的內容還是可以改變的。例如,對於如下語句:  final stringbuffer a=new stringbuffer("immutable");  執行如下語句將報告編譯期錯誤:  a=new stringbuffer("");  但是,執行如下語句則可以通過編譯:  nd(" broken!");  有人在定義方法的參數時,可能想採用如下形式來阻止方法內部修改傳進來的參數對象:  public void method(final stringbuffer param)  {  }  實際上,這是辦不到的,在該方法內部仍然可以增加如下代碼來修改參數對象:  nd("a");  ·"=="和equals方法究竟有什麼區別?  (單獨把一個東西說清楚,然後再說清楚另一個,這樣,它們的區別自然就出來了,混在一起說,則很難說清楚)  ==操作符專門用來比較兩個變量的值是否相等,也就是用於比較變量所對應的內存中所存儲的數值是否相同,要比較兩個基本類型的數據或兩個引用變量是否相等,只能用==操作符。  如果一個變量指向的數據是對象類型的,那麼,這時候涉及了兩塊內存,對象本身佔用一塊內存(堆內存),變量也佔用一塊內存,例如objet obj = new object();變量obj是一個內存,new object()是另一個內存,此時,變量obj所對應的內存中存儲的數值就是對象佔用的那塊內存的首地址。對於指向對象類型的變量,如果要比較兩個變量是否指向同一個對象,即要看這兩個變量所對應的內存中的數值是否相等,這時候就需要用==操作符進行比較。  equals方法是用於比較兩個獨立對象的內容是否相同,就好比去比較兩個人的長相是否相同,它比較的兩個對象是獨立的。例如,對於下面的代碼:  string a=new string("foo");  string b=new string("foo");  兩條new語句創建了兩個對象,然後用a,b這兩個變量分別指向了其中一個對象,這是兩個不同的對象,它們的首地址是不同的,即a和b中存儲的數值是不相同的,所以,表達式a==b將返回false,而這兩個對象中的內容是相同的,所以,表達式ls(b)將返回true。  在實際開發中,我們經常要比較傳遞進行來的字符串內容是否等,例如,string input = …;ls(“quit”),許多人稍不注意就使用==進行比較了,這是錯誤的,隨便從網上找幾個項目實戰的教學視頻看看,裏面就有大量這樣的錯誤。記住,字符串的比較基本上都是使用equals方法。  如果一個類沒有自己定義equals方法,那麼它將繼承object類的equals方法,object類的equals方法的實現代碼如下:  boolean equals(object o){  return this==o;  }  這說明,如果一個類沒有自己定義equals方法,它默認的equals方法(從object 類繼承的)就是使用==操作符,也是在比較兩個變量指向的對象是否是同一對象,這時候使用equals和使用==會得到同樣的結果,如果比較的是兩個獨立的對象則總返回false。如果你編寫的類希望能夠比較該類創建的兩個實例對象的內容是否相同,那麼你必須覆蓋equals方法,由你自己寫代碼來決定在什麼情況即可認爲兩個對象的內容是相同的。  ·靜態變量和實例變量的區別?  在語法定義上的區別:靜態變量前要加static關鍵字,而實例變量前則不加。  在程序運行時的區別:實例變量屬於某個對象的屬性,必須創建了實例對象,其中的實例變量纔會被分配空間,才能使用這個實例變量。靜態變量不屬於某個實例對象,而是屬於類,所以也稱爲類變量,只要程序加載了類的字節碼,不用創建任何實例對象,靜態變量就會被分配空間,靜態變量就可以被使用了。總之,實例變量必須創建對象後纔可以通過這個對象來使用,靜態變量則可以直接使用類名來引用。  例如,對於下面的程序,無論創建多少個實例對象,永遠都只分配了一個staticvar變量,並且每創建一個實例對象,這個staticvar就會加1;但是,每創建一個實例對象,就會分配一個instancevar,即可能分配多個instancevar,並且每個instancevar的值都只自加了1次。  public class varianttest  {  public static int staticvar = 0;  public int instancevar = 0;  public varianttest()  {  staticvar++;  instancevar++;  tln(“staticvar=” + staticvar + ”,instancevar=” + instancevar);  }  }  備註:這個解答除了說清楚兩者的區別外,最後還用一個具體的應用例子來說明兩者的差異,體現了自己有很好的解說問題和設計案例的能力,思維敏捷,超過一般程序員,有寫作能力!  ·是否可以從一個static方法內部發出對非static方法的調用?  不可以。因爲非static方法是要與對象關聯在一起的,必須創建一個對象後,纔可以在該對象上進行方法調用,而static方法調用時不需要創建對象,可以直接調用。也就是說,當一個static方法被調用時,可能還沒有創建任何實例對象,如果從一個static方法中發出對非static方法的調用,那個非static方法是關聯到哪個對象上的呢?這個邏輯無法成立,所以,一個static方法內部發出對非static方法的調用。  ·integer與int的區別  int是java提供的8種原始數據類型之一。java爲每個原始類型提供了封裝類,integer是java爲int提供的封裝類。int的默認值爲0,而integer的默認值爲null,即integer可以區分出未賦值和值爲0的區別,int則無法表達出未賦值的情況,例如,要想表達出沒有參加考試和考試成績爲0的區別,則只能使用integer。在jsp開發中,integer的默認爲null,所以用el表達式在文本框中顯示時,值爲空白字符串,而int默認的默認值爲0,所以用el表達式在文本框中顯示時,結果爲0,所以,int不適合作爲web層的表單數據的類型。  在hibernate中,如果將oid定義爲integer類型,那麼hibernate就可以根據其值是否爲null而判斷一個對象是否是臨時的,如果將oid定義爲了int類型,還需要在hbm映射文件中設置其unsaved-value屬性爲0。  另外,integer提供了多個與整數相關的操作方法,例如,將一個字符串轉換成整數,integer中還定義了表示整數的最大值和最小值的常量。  ·下面的代碼有什麼不妥之處?  1. if(ls(“zxx”){}  2. int x = 1;  return x==1?true:false;