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