隨筆-0  評論-1  文章-13  trackbacks-0

          1.
          abstract class Name {
             private String name;
             public abstract boolean isStupidName(String name) {}
          }
          大俠們,這有何錯誤?
          答案: 錯。Abstract method必須以分號結(jié)尾,且不帶花括號。
          2.
          public class Something {
             void doSomething () {
                 private String s = "";
                 int l = s.length();
             }
          }
          有錯嗎?
          答案: 錯。局部變  量前不能放置任何訪問修飾符 (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(實(shí)現(xiàn))具體細(xì)節(jié)的,怎么可以用private把a(bǔ)bstract
          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;
          }
          和上面的很相似,都是關(guān)于final的問題,這有錯嗎?
          答案: 正確。在addOne method中,參數(shù)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 (實(shí)例變量,或叫成員變量)。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 (實(shí)例變量,或叫成員變量)。Final的instant variable沒有default value,必須在constructor (構(gòu)造器)結(jié)束之前被賦予一個明確的值。可以修改為"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 …";
              }
          }
          看上去很完美。
          答案: 錯??瓷先ピ趍ain里call doSomething沒有什么問題,畢竟兩個methods都在同一個class里。但仔細(xì)看,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();
             }
          }
          答案:錯誤。在編譯時會發(fā)生錯誤(錯誤描述不同的JVM有不同的信息,意思就是未明確的x調(diào)用,兩個x都匹配(就象在同時import java.util和java.sql兩個包時直接聲明Date一樣)。對于父類的變量,可以用super.x來明確,而接口的屬性默認(rèn)隱含為 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());
              }
          }
          這個錯誤不容易發(fā)現(xiàn)。
          答案: 錯。"interface Rollable extends Playable, Bounceable"沒有問題。Interface可繼承多個interfaces,所以這里沒錯。問題出在interface Rollable里的"Ball ball = new Ball("PingPang");"。任何在interface里聲明的interface variable (接口變量,也可稱成員變量),默認(rèn)為public static final。也就是說"Ball ball = new Ball("PingPang");"實(shí)際上是"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是不能被改變r(jià)eference的。因此編譯器將在"ball = new Ball("Football");"這里顯示有錯。

          posted on 2008-09-05 17:39 飛行魚 閱讀(115) 評論(0)  編輯  收藏 所屬分類: 面試題

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 唐河县| 陆丰市| 玉林市| 神池县| 永宁县| 贵定县| 永年县| 盐城市| 田林县| 梧州市| 平果县| 安陆市| 抚州市| 新乡市| 开封市| 蓬莱市| 滨海县| 军事| 隆德县| 赤水市| 浏阳市| 密山市| 扎囊县| 濮阳县| 柯坪县| 张家口市| 白银市| 东源县| 隆尧县| 吉安县| 康马县| 霍林郭勒市| 历史| 泰和县| 万宁市| 永宁县| 报价| 新河县| 宁城县| 峡江县| 黑河市|