電子書下載地址: http://wiki.jikexueyuan.com/project/java-interview-bible/
1. 說(shuō)說(shuō) & 和 && 的區(qū)別。
& 和 && 都可以用作邏輯與的運(yùn)算符,表示邏輯與(and),當(dāng)運(yùn)算符兩邊的表達(dá)式的結(jié)果都為 true 時(shí),整個(gè)運(yùn)算結(jié)果才為 true,否則,只要有一方為 false,則結(jié)果為 false。
&& 還具有短路的功能,即如果第一個(gè)表達(dá)式為 false,則不再計(jì)算第二個(gè)表達(dá)式,例如,對(duì)于 if(str != null&& !str.equals(“”))
表達(dá)式,當(dāng) str 為 null 時(shí),后面的表達(dá)式不會(huì)執(zhí)行,所以不會(huì)出現(xiàn) NullPointerException 如果將 && 改為 & ,則會(huì)拋出NullPointerException 異常。If(x==33 & ++y>0) y
會(huì)增長(zhǎng), If(x==33 && ++y>0)
不會(huì)增長(zhǎng)。
& 還可以用作位運(yùn)算符,當(dāng) & 操作符兩邊的表達(dá)式不是 boolean 類型時(shí),& 表示按位與操作,我們通常使用 0x0f 來(lái)與一個(gè)整數(shù)進(jìn)行 & 運(yùn)算,來(lái)獲取該整數(shù)的最低 4 個(gè) bit 位,例如,0x31 & 0x0f 的結(jié)果為 0x01。
備注:這道題先說(shuō)兩者的共同點(diǎn),再說(shuō)出 && 和 & 的特殊之處,并列舉一些經(jīng)典的例子來(lái)表明自己理解透徹深入、實(shí)際經(jīng)驗(yàn)豐富。
2. 用最有效率的方法算出 2 乘以 8 等於幾?
2 << 3,因?yàn)閷⒁粋€(gè)數(shù)左移 n 位,就相當(dāng)于乘以了 2 的 n 次方,那么,一個(gè)數(shù)乘以 8 只要將其左移 3 位即可,而位運(yùn)算 cpu 直接支持的,效率最高,所以,2 乘以 8 等於幾的最效率的方法是 2 << 3 。
3. 存在使 i + 1 < i的數(shù)嗎?
答案:存在
解析:如果 i 為 int 型,那么當(dāng) i 為 int 能表示的最大整數(shù)時(shí),i+1
就溢出變成負(fù)數(shù)了,此時(shí)不就 <i 了嗎。
擴(kuò)展:存在使 i > j || i <= j
不成立的數(shù)嗎?
答案:存在
解析:比如 Double.NaN 或 Float.NaN 。
4. 0.6332 的數(shù)據(jù)類型是()
A. float
B. double
C. Float
D. Double
答案:B
解析:默認(rèn)為 double 型,如果為 float 型需要加上f顯示說(shuō)明,即 0.6332f
5. System.out.println("5" + 2);的輸出結(jié)果應(yīng)該是()。
A. 52
B. 7
C. 2
D. 5
答案:A
解析:沒(méi)啥好說(shuō)的,Java 會(huì)自動(dòng)將 2 轉(zhuǎn)換為字符串。
6. 下面的方法,當(dāng)輸入為 2 的時(shí)候返回值是多少?
public static int getValue(int i) {
int result = 0;
switch (i) {
case 1:
result = result + i;
case 2:
result = result + i * 2;
case 3:
result = result + i * 3;
}
return result;
}
A. 0
B. 2
C. 4
D. 10
答案:D
解析:注意這里 case 后面沒(méi)有加 break,所以從case 2開始一直往下運(yùn)行。
7. float f=3.4;是否正確?
答:不正確。3.4 是雙精度數(shù),將雙精度型(double)賦值給浮點(diǎn)型(float)屬于下轉(zhuǎn)型(down-casting,也稱為窄化)會(huì)造成精度損失,因此需要強(qiáng)制類型轉(zhuǎn)換float f =(float)3.4; 或者寫成 float f =3.4F;。
8. int 和 Integer 有什么區(qū)別?
答:Java 是一個(gè)近乎純潔的面向?qū)ο缶幊陶Z(yǔ)言,但是為了編程的方便還是引入不是對(duì)象的基本數(shù)據(jù)類型,但是為了能夠?qū)⑦@些基本數(shù)據(jù)類型當(dāng)成對(duì)象操作,Java 為每一個(gè)基本數(shù)據(jù)類型都引入了對(duì)應(yīng)的包裝類型(wrapper class),int 的包裝類就是 Integer,從 JDK 1.5 開始引入了自動(dòng)裝箱/拆箱機(jī)制,使得二者可以相互轉(zhuǎn)換。
Java 為每個(gè)原始類型提供了包裝類型:
原始類型: boolean,char,byte,short,int,long,float,double
包裝類型:Boolean,Character,Byte,Short,Integer,Long,F(xiàn)loat,Double
package com.lovo;
public class AutoUnboxingTest {
public static void main(String[] args) {
Integer a = new Integer(3);
Integer b = 3; // 將3自動(dòng)裝箱成Integer類型
int c = 3;
System.out.println(a == b); // false 兩個(gè)引用沒(méi)有引用同一對(duì)象
System.out.println(a == c); // true a自動(dòng)拆箱成int類型再和c比較
}
}
9. char 型變量中能不能存貯一個(gè)中文漢字?為什么?
答:char 類型可以存儲(chǔ)一個(gè)中文漢字,因?yàn)?Java 中使用的編碼是 Unicode(不選擇任何特定的編碼,直接使用字符在字符集中的編號(hào),這是統(tǒng)一的唯一方法),一個(gè) char 類型占 2 個(gè)字節(jié)(16bit),所以放一個(gè)中文是沒(méi)問(wèn)題的。
補(bǔ)充:使用 Unicode 意味著字符在 JVM 內(nèi)部和外部有不同的表現(xiàn)形式,在 JVM 內(nèi)部都是 Unicode,當(dāng)這個(gè)字符被從 JVM 內(nèi)部轉(zhuǎn)移到外部時(shí)(例如存入文件系統(tǒng)中),需要進(jìn)行編碼轉(zhuǎn)換。所以 Java 中有字節(jié)流和字符流,以及在字符流和字節(jié)流之間進(jìn)行轉(zhuǎn)換的轉(zhuǎn)換流,如 InputStreamReader 和 OutputStreamReader,這兩個(gè)類是字節(jié)流和字符流之間的適配器類,承擔(dān)了編碼轉(zhuǎn)換的任務(wù);對(duì)于 C 程序員來(lái)說(shuō),要完成這樣的編碼轉(zhuǎn)換恐怕要依賴于union(聯(lián)合體/共用體)共享內(nèi)存的特征來(lái)實(shí)現(xiàn)了。
10. Math.round(11.5) 等于多少? Math.round(-11.5)等于多少?
答:Math.round(11.5)==12 Math.round(-11.5)==-11 round 方法返回與參數(shù) 最接近的長(zhǎng)整數(shù),參數(shù)加 1/2 后求其 floor