面試?yán)}1:以下代碼編譯時會產(chǎn)生錯誤的是______。[Trend公司2005年面試題]
class reverseIt4{
public static void main(String[] args)
{
EnclosingClass jb2; //-----1
System.out.println(jb2.m); //-----2
}}class EnclosingClass //--------3{
public int m = 6;
class InnerClass //-------4
{
int msquare;
InnerClass()
{
msquare = m*m;
}
}}
A.語句1 B.語句2 C.語句3 D.語句4
解析:語句3和語句4顯然是正確的,盡管它們的描述不是那么規(guī)范(存在一個類中的類)。語句1聲明了一個類,但是沒有做定義,于是問題就出現(xiàn)了。聲明好比只是告訴編譯器有一個人,但是如果不定義,這個人就是個抽象的人,沒有身高、體重、年齡、職業(yè)的“空”人。所以定義對象必須在聲明的同時給它定義。正確的程序如下。
class reverseIt4{
public static void main(String[] args)
{
EnclosingClass jb = new EnclosingClass();
System.out.println(jb.m);
}}class EnclosingClass{
public int m = 6;
class InnerClass
{
int msquare;
InnerClass()
{
msquare = m*m;
}
}}
答案:該題是問編譯在哪兒出現(xiàn)問題,盡管問題出在1處,但編譯器不會發(fā)現(xiàn),編譯器只有在2處才會發(fā)現(xiàn)問題。所以答案選B。
面試?yán)}2:Object是所有類的父類,任何類都默認(rèn)繼承Object。Object類到底實現(xiàn)了哪些方法?
答案:
1.clone方法
保護(hù)方法,實現(xiàn)對象的淺復(fù)制,只有實現(xiàn)了Cloneable接口才可以調(diào)用該方法,否則拋出CloneNotSupportedException異常。
2.getClass方法
final方法,獲得運(yùn)行時類型。
3.toString方法
該方法用得比較多,一般子類都有覆蓋。
4.finalize方法
該方法用于釋放資源。因為無法確定該方法什么時候被調(diào)用,很少使用。
5.equals方法
該方法是非常重要的一個方法。一般equals和==是不一樣的,但是在Object中兩者是一樣的。子類一般都要重寫這個方法。
6.hashCode方法
該方法用于哈希查找,重寫了equals方法一般都要重寫hashCode方法。這個方法在一些具有哈希功能的Collection中用到。
一般必須滿足obj1.equals(obj2)==true??梢酝瞥鰋bj1.hash- Code()==obj2.hashCode(),但是hashCode相等不一定就滿足equals。不過為了提高效率,應(yīng)該盡量使上面兩個條件接近等價。
7.wait方法
wait方法就是使當(dāng)前線程等待該對象的鎖,當(dāng)前線程必須是該對象的擁有者,也就是具有該對象的鎖。wait()方法一直等待,直到獲得鎖或者被中斷。wait(long timeout)設(shè)定一個超時間隔,如果在規(guī)定時間內(nèi)沒有獲得鎖就返回。
調(diào)用該方法后當(dāng)前線程進(jìn)入睡眠狀態(tài),直到以下事件發(fā)生。
?。?)其他線程調(diào)用了該對象的notify方法。
?。?)其他線程調(diào)用了該對象的notifyAll方法。
?。?)其他線程調(diào)用了interrupt中斷該線程。(4)時間間隔到了。
此時該線程就可以被調(diào)度了,如果是被中斷的話就拋出一個InterruptedException異常。
8.notify方法
該方法喚醒在該對象上等待的某個線程。
9.notifyAll方法
該方法喚醒在該對象上等待的所有線程。