當前位置:才華齋>計算機>java語言>

計算機考試java程式碼查錯練習

java語言 閱讀(2.14W)

不向前走,不知路遠;不努力學習,不明白真理。以下是小編為大家搜尋整理的計算機考試java程式碼查錯練習,希望能給大家帶來幫助!更多精彩內容請及時關注我們應屆畢業生考試網!

計算機考試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 = th();

}

}

有錯嗎?

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

(final如同abstract和strictfp,都是非訪問修飾符,strictfp只能修飾class和method而非variable)。

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()ne(o);

}

public void addOne(final Other o) {

o.i++;

}

}

class Other {

public int i;

}

和上面的很相似,都是關於final的問題,這有錯嗎?

答案: 正確。在addOne method中,引數o被修飾成final。如果在addOne method裡我們修改了o的reference

(比如: o = new Other();),那麼如同上例這題也是錯的。但這裡修改的是o的member vairable

(成員變數),而o的reference並沒有改變。

6.

class Something {

int i;

public void doSomething() {

tln("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() {

tln("i = " + i);

}

}

和上面一題只有一個地方不同,就是多了一個final。這難道就錯了嗎?

答案: 錯。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();

tln("mething() returns " + doSomething());

}

public String doSomething() {

return "Do something ...";

}

}

看上去很完美。

答案: 錯。看上去在main裡call doSomething沒有什麼問題,畢竟兩個methods都在同一個class裡。但仔細看,main是static的。static method不能直接call non-static methods。可改成"tln("mething() returns " + mething());"。同理,static method不能訪問non-static instant variable。

9.

此處,Something類的檔名叫

class Something {

private static void main(String[] something_to_do) {

tln("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(){

tln(x);

}

public static void main(String[] args) {

new C()();

}

}

答案:錯誤。在編譯時會發生錯誤(錯誤描述不同的JVM有不同的資訊,意思就是未明確的x呼叫,兩個x都匹配(就象在同時import 和兩個包時直接宣告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) {

= name;

}

public void play() {

ball = new Ball("Football");

tln(ame());

}

}

這個錯誤不容易發現。

答案: 錯。"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");"這裡顯示有錯。