JAVA代碼查錯

介紹了Java編程方面常見的誤區java

###1.sql

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

這段代碼有何錯誤:abstract method必須以分號結尾,且不帶花括號。編程

###2.this

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

這段代碼有何錯誤:局部變量前不能放置任何訪問修飾符(private,public,和protected)。final能夠用來修飾局部變量(final如同abstract和strictfp,都是非訪問修飾符,strictfp只能修飾class和method而非variable)。code

###3.繼承

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

這段代碼有何錯誤:abstract的methods不能以private修飾。abstract的methods就是讓子類implement(實現)具體細節的,怎麼能夠用private把abstract method封鎖起來呢? (同理,abstract method前不能加final)。接口

###4.get

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;
}

和上面的很類似,都是關於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() {
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。這難道就錯了嗎? 答案: 錯。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。可改爲"System.out.println("s.doSomething() returns " + s.doSomething());"。同理,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");"這裏顯示有錯。

相關文章
相關標籤/搜索