1. 程式人生 > >java面試-判斷+程式碼查錯

java面試-判斷+程式碼查錯

判斷
short s1 = 1; s1 = s1 + 1; (s1+1運算結果是int型,需要強制轉換型別)
short s1 = 1; s1 += 1;(可以正確編譯, +=預設強制轉換)
1、Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
Math.round(11.5)==12
Math.round(-11.5)==-11
round方法返回與引數最接近的長整數,引數加1/2後求其floor.
2、String s = new String(“xyz”);建立了幾個String Object?
兩個

JAVA程式碼查錯
1.

abstract class Name {
private String name;
public abstract boolean isStupidName(String name) {}
}

答案: 錯。abstract method必須以分號結尾,且不帶花括號。
2.

public class Something {
void doSomething () {
private String s = "";
int l = s.length();
}
}

答案: 錯。區域性變數前不能放置任何訪問修飾符 (private,public,和protected)。
final可以用來修飾區域性變數,是非訪問修飾符
3.

abstract class Something {
private abstract String doSomething ();
}

答案: 錯。abstract的methods不能以private修飾。abstract的methods就是讓子類implement(實現)具體細節的,怎麼可以用private把abstract
method封鎖起來呢? (同理,abstract method前不能加final)。
4.

public class Something {
public int addOne(final int x) {
return ++x;
}
}

答案: 錯。int x被修飾成final,意味著x不能在addOne method中被修改。
5.

public class Something {
public static void main(String[] args) {
Other o = new Other();
new Something().addOne(o);
}
public void addOne(final Other o) {
o.i++;
}
}
class Other {
public int i;
}

答案: 正確。在addOne method中,引數o被修飾成final。如果在addOne method裡我們修改了o的reference(比如: o = new Other();),那麼如同上例這題也是錯的。但這裡修改的是o的member vairable
(成員變數),而o的reference並沒有改變。
6.

class Something {
int i;
public void doSomething() {
System.out.println("i = " + i);
}
} 

答案: 正確。輸出的是”i = 0”。int i屬於instant variable (例項變數,或叫成員變數)。instant variable有default value。int的default value是0。
7.

class Something {
final int i;
public void doSomething() {
System.out.println("i = " + i);
}
}

答案: 錯。final int i是個final的instant variable (例項變數,或叫成員變數)。final的instant variable沒有default value,必須在constructor (構造器)結束之前被賦予一個明確的值。可以修改為”final int i = 0;”。
8.

public class Something {
public static void main(String[] args) {
Something s = new Something();
System.out.println("s.doSomething() returns " + doSomething());
}
public String doSomething() {
return "Do something ...";
}
}

看上去很完美。
答案: 錯。看上去在main裡call doSomething沒有什麼問題,畢竟兩個methods都在同一個class裡。但仔細看,main是static的。
static method不能直接call non-static methods。
同理,static method不能訪問non-static instant variable。
9.

此處,Something類的檔名叫OtherThing.java
class Something {

private static void main(String[] something_to_do) { 
System.out.println("Do something ...");
}
}

這個好像很明顯。
答案: 正確。從來沒有人說過Java的Class名字必須和其檔名相同。但public class的名字必須和檔名相同。
10.

interface A{
int x = 0;
}
class B{
int x =1;
}
class C extends B implements A {
public void pX(){
System.out.println(x);
}
public static void main(String[] args) {
new C().pX();
}
}

答案:錯誤。在編譯時會發生錯誤(錯誤描述不同的JVM有不同的資訊,意思就是未明確的x呼叫,兩個x都匹配(就象在同時import java.util和java.sql兩個包時直接宣告Date一樣)。對於父類的變數,可以用super.x來明確,而介面的屬性預設隱含為 public static final.所以可以通過A.x來明確。
11

interface Playable {
void play();
}
interface Bounceable {
void play();
}
interface Rollable extends Playable, Bounceable {
Ball ball = new Ball("PingPang");
}
class Ball implements Rollable {
    private String name;
    public String getName() {
    return name;
    }
    public Ball(String name) {
    this.name = name; 
    }
    public void play() {
    ball = new Ball("Football");
    System.out.println(ball.getName());
    }
}

這個錯誤不容易發現。
答案: 錯。”interface Rollable extends Playable, Bounceable”沒有問題。interface可繼承多個interfaces,所以這裡沒錯。問題出在interface Rollable裡的”Ball ball = new Ball(“PingPang”);”。任何在interface裡宣告的interface variable (介面變數,也可稱成員變數),預設為public static final。也就是說”Ball ball = new Ball(“PingPang”);”實際上是”public static final Ball ball = new Ball(“PingPang”);”。在Ball類的Play()方法中,”ball = new Ball(“Football”);”改變了ball的reference,而這裡的ball來自Rollable interface,Rollable interface裡的ball是public static final的,final的object是不能被改變reference的。因此編譯器將在”ball = new Ball(“Football”);”這裡顯示有錯。