- 相關(guān)推薦
JAVA筆試經(jīng)驗
JAVA筆試必備題
·short s1 = 1; s1 = s1 + 1;有什么錯? short s1 = 1; s1 += 1;有什么錯?
對于short s1 = 1; s1 = s1 + 1; 由于s1+1運算時(shí)會(huì )自動(dòng)提升表達式的類(lèi)型,所以結果是int型,再賦值給short類(lèi)型s1時(shí),編譯器將報告需要強制轉換類(lèi)型的錯誤。
對于short s1 = 1; s1 += 1;由于 += 是java語(yǔ)言規定的運算符,java編譯器會(huì )對它進(jìn)行特殊處理,因此可以正確編譯。
·用最有效率的方法算出2乘以8等於幾?
2 << 3,
因為將一個(gè)數左移n位,就相當于乘以了2的n次方,那么,一個(gè)數乘以8只要將其左移3位即可,而位運算cpu直接支持的,效率最高,所以,2乘以8等於幾的最效率的方法是2 << 3。
·請設計一個(gè)一百億的計算器
首先要明白這道題目的考查點(diǎn)是什么,一是大家首先要對計算機原理的底層細節要清楚、要知道加減法的位運算原理和知道計算機中的算術(shù)運算會(huì )發(fā)生越界的情況,二是要具備一定的面向對象的設計思想。
首先,計算機中用固定數量的幾個(gè)字節來(lái)存儲的數值,所以計算機中能夠表示的數值是有一定的范圍的,為了便于講解和理解,我們先以byte 類(lèi)型的整數為例,它用1個(gè)字節進(jìn)行存儲,表示的最大數值范圍為-128到+127。-1在內存中對應的二進(jìn)制數據為11111111,如果兩個(gè)-1相加,不考慮Java運算時(shí)的類(lèi)型提升,運算后會(huì )產(chǎn)生進(jìn)位,二進(jìn)制結果為1,11111110,由于進(jìn)位后超過(guò)了byte類(lèi)型的存儲空間,所以進(jìn)位部分被舍棄,即最終的結果為11111110,也就是-2,這正好利用溢位的方式實(shí)現了負數的運算。-128在內存中對應的二進(jìn)制數據為10000000,如果兩個(gè)-128相加,不考慮Java運算時(shí)的類(lèi)型提升,運算后會(huì )產(chǎn)生進(jìn)位,二進(jìn)制結果為1,00000000,由于進(jìn)位后超過(guò)了byte類(lèi)型的存儲空間,所以進(jìn)位部分被舍棄,即最終的結果為00000000,也就是0,這樣的結果顯然不是我們期望的,這說(shuō)明計算機中的算術(shù)運算是會(huì )發(fā)生越界情況的,兩個(gè)數值的運算結果不能超過(guò)計算機中的該類(lèi)型的數值范圍。由于Java中涉及表達式運算時(shí)的類(lèi)型自動(dòng)提升,我們無(wú)法用byte類(lèi)型來(lái)做演示這種問(wèn)題和現象的實(shí)驗,大家可以用下面一個(gè)使用整數做實(shí)驗的例子程序體驗一下:
int a = Integer.MAX_VALUE;
int b = Integer.MAX_VALUE;
int sum = a + b;
System.out.println(“a=”+a+”,b=”+b+”,sum=”+sum);
先不考慮long類(lèi)型,由于int的正數范圍為2的31次方,表示的最大數值約等于2*1000*1000*1000,也就是20億的大小,所以,要實(shí)現一個(gè)一百億的計算器,我們得自己設計一個(gè)類(lèi)可以用于表示很大的整數,并且提供了與另外一個(gè)整數進(jìn)行加減乘除的功能,大概功能如下:
()這個(gè)類(lèi)內部有兩個(gè)成員變量,一個(gè)表示符號,另一個(gè)用字節數組表示數值的二進(jìn)制數
()有一個(gè)構造方法,把一個(gè)包含有多位數值的字符串轉換到內部的符號和字節數組中
()提供加減乘除的功能
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)
{
}
}
備注:要想寫(xiě)出這個(gè)類(lèi)的完整代碼,是非常復雜的,如果有興趣的話(huà),可以參看jdk中自帶的java.math.BigInteger類(lèi)的源碼。面試的人也知道誰(shuí)都不可能在短時(shí)間內寫(xiě)出這個(gè)類(lèi)的完整代碼的,他要的是你是否有這方面的概念和意識,他最重要的還是考查你的能力,所以,你不要因為自己無(wú)法寫(xiě)出完整的最終結果就放棄答這道題,你要做的就是你比別人寫(xiě)得多,證明你比別人強,你有這方面的思想意識就可以了,畢竟別人可能連題目的意思都看不懂,什么都沒(méi)寫(xiě),你要敢于答這道題,即使只答了一部分,那也與那些什么都不懂的人區別出來(lái),拉開(kāi)了距離,算是矮子中的高個(gè),機會(huì )當然就屬于你了。另外,答案中的框架代碼也很重要,體現了一些面向對象設計的功底,特別是其中的方法命名很專(zhuān)業(yè),用的英文單詞很精準,這也是能力、經(jīng)驗、專(zhuān)業(yè)性、英語(yǔ)水平等多個(gè)方面的體現,會(huì )給人留下很好的印象,在編程能力和其他方面條件差不多的情況下,英語(yǔ)好除了可以使你獲得更多機會(huì )外,薪水可以高出一千元。
·使用final關(guān)鍵字修飾一個(gè)變量時(shí),是引用不能變,還是引用的對象不能變?
使用final關(guān)鍵字修飾一個(gè)變量時(shí),是指引用變量不能變,引用變量所指向的對象中的內容還是可以改變的。例如,對于如下語(yǔ)句:
final StringBuffer a=new StringBuffer("immutable");
執行如下語(yǔ)句將報告編譯期錯誤:
a=new StringBuffer("");
但是,執行如下語(yǔ)句則可以通過(guò)編譯:
a.append(" broken!");
有人在定義方法的參數時(shí),可能想采用如下形式來(lái)阻止方法內部修改傳進(jìn)來(lái)的參數對象:
public void method(final StringBuffer param)
{
}
實(shí)際上,這是辦不到的,在該方法內部仍然可以增加如下代碼來(lái)修改參數對象:
param.append("a");
·"=="和equals方法究竟有什么區別?
(單獨把一個(gè)東西說(shuō)清楚,然后再說(shuō)清楚另一個(gè),這樣,它們的區別自然就出來(lái)了,混在一起說(shuō),則很難說(shuō)清楚)
==操作符專(zhuān)門(mén)用來(lái)比較兩個(gè)變量的值是否相等,也就是用于比較變量所對應的內存中所存儲的數值是否相同,要比較兩個(gè)基本類(lèi)型的數據或兩個(gè)引用變量是否相等,只能用==操作符。
如果一個(gè)變量指向的數據是對象類(lèi)型的,那么,這時(shí)候涉及了兩塊內存,對象本身占用一塊內存(堆內存),變量也占用一塊內存,例如Objet obj = new Object();變量obj是一個(gè)內存,new Object()是另一個(gè)內存,此時(shí),變量obj所對應的內存中存儲的數值就是對象占用的那塊內存的首地址。對于指向對象類(lèi)型的變量,如果要比較兩個(gè)變量是否指向同一個(gè)對象,即要看這兩個(gè)變量所對應的內存中的數值是否相等,這時(shí)候就需要用==操作符進(jìn)行比較。
equals方法是用于比較兩個(gè)獨立對象的內容是否相同,就好比去比較兩個(gè)人的長(cháng)相是否相同,它比較的兩個(gè)對象是獨立的。例如,對于下面的代碼:
String a=new String("foo");
String b=new String("foo");
兩條new語(yǔ)句創(chuàng )建了兩個(gè)對象,然后用a,b這兩個(gè)變量分別指向了其中一個(gè)對象,這是兩個(gè)不同的對象,它們的首地址是不同的,即a和b中存儲的數值是不相同的,所以,表達式a==b將返回false,而這兩個(gè)對象中的內容是相同的,所以,表達式a.equals(b)將返回true。
在實(shí)際開(kāi)發(fā)中,我們經(jīng)常要比較傳遞進(jìn)行來(lái)的字符串內容是否等,例如,String input = …;input.equals(“quit”),許多人稍不注意就使用==進(jìn)行比較了,這是錯誤的,隨便從網(wǎng)上找幾個(gè)項目實(shí)戰的教學(xué)視頻看看,里面就有大量這樣的錯誤。記住,字符串的比較基本上都是使用equals方法。
如果一個(gè)類(lèi)沒(méi)有自己定義equals方法,那么它將繼承Object類(lèi)的equals方法,Object類(lèi)的equals方法的實(shí)現代碼如下:
boolean equals(Object o){
return this==o;
}
這說(shuō)明,如果一個(gè)類(lèi)沒(méi)有自己定義equals方法,它默認的equals方法(從Object 類(lèi)繼承的)就是使用==操作符,也是在比較兩個(gè)變量指向的對象是否是同一對象,這時(shí)候使用equals和使用==會(huì )得到同樣的結果,如果比較的是兩個(gè)獨立的對象則總返回false。如果你編寫(xiě)的類(lèi)希望能夠比較該類(lèi)創(chuàng )建的兩個(gè)實(shí)例對象的內容是否相同,那么你必須覆蓋equals方法,由你自己寫(xiě)代碼來(lái)決定在什么情況即可認為兩個(gè)對象的內容是相同的。
·靜態(tài)變量和實(shí)例變量的區別?
在語(yǔ)法定義上的區別:靜態(tài)變量前要加static關(guān)鍵字,而實(shí)例變量前則不加。
在程序運行時(shí)的區別:實(shí)例變量屬于某個(gè)對象的屬性,必須創(chuàng )建了實(shí)例對象,其中的實(shí)例變量才會(huì )被分配空間,才能使用這個(gè)實(shí)例變量。靜態(tài)變量不屬于某個(gè)實(shí)例對象,而是屬于類(lèi),所以也稱(chēng)為類(lèi)變量,只要程序加載了類(lèi)的字節碼,不用創(chuàng )建任何實(shí)例對象,靜態(tài)變量就會(huì )被分配空間,靜態(tài)變量就可以被使用了?傊,實(shí)例變量必須創(chuàng )建對象后才可以通過(guò)這個(gè)對象來(lái)使用,靜態(tài)變量則可以直接使用類(lèi)名來(lái)引用。
例如,對于下面的程序,無(wú)論創(chuàng )建多少個(gè)實(shí)例對象,永遠都只分配了一個(gè)staticVar變量,并且每創(chuàng )建一個(gè)實(shí)例對象,這個(gè)staticVar就會(huì )加1;但是,每創(chuàng )建一個(gè)實(shí)例對象,就會(huì )分配一個(gè)instanceVar,即可能分配多個(gè)instanceVar,并且每個(gè)instanceVar的值都只自加了1次。
public class VariantTest
{
public static int staticVar = 0;
public int instanceVar = 0;
public VariantTest()
{
staticVar++;
instanceVar++;
System.out.println(“staticVar=” + staticVar + ”,instanceVar=” + instanceVar);
}
}
備注:這個(gè)解答除了說(shuō)清楚兩者的區別外,最后還用一個(gè)具體的應用例子來(lái)說(shuō)明兩者的差異,體現了自己有很好的解說(shuō)問(wèn)題和設計案例的能力,思維敏捷,超過(guò)一般程序員,有寫(xiě)作能力!
·是否可以從一個(gè)static方法內部發(fā)出對非static方法的調用?
不可以。因為非static方法是要與對象關(guān)聯(lián)在一起的,必須創(chuàng )建一個(gè)對象后,才可以在該對象上進(jìn)行方法調用,而static方法調用時(shí)不需要創(chuàng )建對象,可以直接調用。也就是說(shuō),當一個(gè)static方法被調用時(shí),可能還沒(méi)有創(chuàng )建任何實(shí)例對象,如果從一個(gè)static方法中發(fā)出對非static方法的調用,那個(gè)非static方法是關(guān)聯(lián)到哪個(gè)對象上的呢?這個(gè)邏輯無(wú)法成立,所以,一個(gè)static方法內部發(fā)出對非static方法的調用。
·Integer與int的區別
int是java提供的8種原始數據類(lèi)型之一。Java為每個(gè)原始類(lèi)型提供了封裝類(lèi),Integer是java為int提供的封裝類(lèi)。int的默認值為0,而Integer的默認值為null,即Integer可以區分出未賦值和值為0的區別,int則無(wú)法表達出未賦值的情況,例如,要想表達出沒(méi)有參加考試和考試成績(jì)?yōu)?的區別,則只能使用Integer。在JSP開(kāi)發(fā)中,Integer的默認為null,所以用el表達式在文本框中顯示時(shí),值為空白字符串,而int默認的默認值為0,所以用el表達式在文本框中顯示時(shí),結果為0,所以,int不適合作為web層的表單數據的類(lèi)型。
在Hibernate中,如果將OID定義為Integer類(lèi)型,那么Hibernate就可以根據其值是否為null而判斷一個(gè)對象是否是臨時(shí)的,如果將OID定義為了int類(lèi)型,還需要在hbm映射文件中設置其unsaved-value屬性為0。
另外,Integer提供了多個(gè)與整數相關(guān)的操作方法,例如,將一個(gè)字符串轉換成整數,Integer中還定義了表示整數的最大值和最小值的常量。
·下面的代碼有什么不妥之處?
1. if(username.equals(“zxx”){}
2. int x = 1;
return x==1?true:false;
【JAVA筆試經(jīng)驗】相關(guān)文章:
java筆試題及答案08-20
筆試經(jīng)驗:筆試內容準備11-21
JAVA面試筆試題11-15
經(jīng)典java筆試題及答案分享02-25
華為Java筆試題一11-21
java面試的經(jīng)驗11-20
筆試的經(jīng)驗分享11-21
BJ筆試的經(jīng)驗11-21
實(shí)習筆試經(jīng)驗11-21
求筆試經(jīng)驗11-19