Edzy_Java

            BlogJava :: 首頁 ::  ::  ::  :: 管理 ::
            58 隨筆 :: 12 文章 :: 11 評論 :: 0 Trackbacks

          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可以用來修飾局部變量

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

          }

          public void addOne(final Other o) {

          o.i++;

          }

          }

          class Other {

          public int i;

          }

          *** 當對象作為參數傳遞時, 如果被聲明為 final 時, 則不能改變對象參數的引用.

          和上面的很相似,都是關于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");"這里顯示有錯。

           

          JAVA編程題

          1.現在輸入n個數字,以逗號,分開;然后可選擇升或者降序排序;按提交鍵就在另一頁面顯示按什么排序,結果為,提供reset

          import java.util.*;

          public class bycomma{

          public static String[] splitStringByComma(String source){

          if(source==null||source.trim().equals(""))

          return null;

          StringTokenizer commaToker = new StringTokenizer(source,",");

          String[] result = new String[commaToker.countTokens()];

          int i=0;

          while(commaToker.hasMoreTokens()){

          result[i] = commaToker.nextToken();

          i++;

          }

          return result;

          }

          public static void main(String args[]){

          String[] s = splitStringByComma("5,8,7,4,3,9,1");

          int[] ii = new int[s.length];

          for(int i = 0;i<s.length;i++){

          ii[i] =Integer.parseInt(s[i]);

          }

          Arrays.sort(ii);

          //asc

          for(int i=0;i<s.length;i++){

          System.out.println(ii[i]);

          }

          //desc

          for(int i=(s.length-1);i>=0;i--){

          System.out.println(ii[i]);

          }

          }

          }

          2.金額轉換,阿拉伯數字的金額轉換成中國傳統的形式如:(¥1011)->(一千零一拾一元整)輸出。

          package test.format;

          import java.text.NumberFormat;

          import java.util.HashMap;

          public class SimpleMoneyFormat {

          public static final String EMPTY = "";

          public static final String ZERO = "零";

          public static final String ONE = "壹";

          public static final String TWO = "貳";

          public static final String THREE = "叁";

          public static final String FOUR = "肆";

          public static final String FIVE = "伍";

          public static final String SIX = "陸";

          public static final String SEVEN = "柒";

          public static final String EIGHT = "捌";

          public static final String NINE = "玖";

          public static final String TEN = "拾";

          public static final String HUNDRED = "佰";

          public static final String THOUSAND = "仟";

          public static final String TEN_THOUSAND = "萬";

          public static final String HUNDRED_MILLION = "億";

          public static final String YUAN = "元";

          public static final String JIAO = "角";

          public static final String FEN = "分";

          public static final String DOT = ".";

          private static SimpleMoneyFormat formatter = null;

          private HashMap chineseNumberMap = new HashMap();

          private HashMap chineseMoneyPattern = new HashMap();

          private NumberFormat numberFormat = NumberFormat.getInstance();

          private SimpleMoneyFormat() {

          numberFormat.setMaximumFractionDigits(4);

          numberFormat.setMinimumFractionDigits(2);

          numberFormat.setGroupingUsed(false);

          chineseNumberMap.put("0", ZERO);

          chineseNumberMap.put("1", ONE);

          chineseNumberMap.put("2", TWO);

          chineseNumberMap.put("3", THREE);

          chineseNumberMap.put("4", FOUR);

          chineseNumberMap.put("5", FIVE);

          chineseNumberMap.put("6", SIX);

          chineseNumberMap.put("7", SEVEN);

          chineseNumberMap.put("8", EIGHT);

          chineseNumberMap.put("9", NINE);

          chineseNumberMap.put(DOT, DOT);

          chineseMoneyPattern.put("1", TEN);

          chineseMoneyPattern.put("2", HUNDRED);

          chineseMoneyPattern.put("3", THOUSAND);

          chineseMoneyPattern.put("4", TEN_THOUSAND);

          chineseMoneyPattern.put("5", TEN);

          chineseMoneyPattern.put("6", HUNDRED);

          chineseMoneyPattern.put("7", THOUSAND);

          chineseMoneyPattern.put("8", HUNDRED_MILLION);

          }

          public static SimpleMoneyFormat getInstance() {

          if (formatter == null)

          formatter = new SimpleMoneyFormat();

          return formatter;

          }

          public String format(String moneyStr) {

          checkPrecision(moneyStr);

          String result;

          result = convertToChineseNumber(moneyStr);

          result = addUnitsToChineseMoneyString(result);

          return result;

          }

          public String format(double moneyDouble) {

          return format(numberFormat.format(moneyDouble));

          }

          public String format(int moneyInt) {

          return format(numberFormat.format(moneyInt));

          }

          public String format(long moneyLong) {

          return format(numberFormat.format(moneyLong));

          }

          public String format(Number moneyNum) {

          return format(numberFormat.format(moneyNum));

          }

          private String convertToChineseNumber(String moneyStr) {

          String result;

          StringBuffer cMoneyStringBuffer = new StringBuffer();

          for (int i = 0; i < moneyStr.length(); i++) {

          cMoneyStringBuffer.append(chineseNumberMap.get(moneyStr.substring(i, i + 1)));

          }

          //拾佰仟萬億等都是漢字里面才有的單位,加上它們

          int indexOfDot = cMoneyStringBuffer.indexOf(DOT);

          int moneyPatternCursor = 1;

          for (int i = indexOfDot - 1; i > 0; i--) {

          cMoneyStringBuffer.insert(i, chineseMoneyPattern.get(EMPTY + moneyPatternCursor));

          moneyPatternCursor = moneyPatternCursor == 8 ? 1 : moneyPatternCursor + 1;

          }

          String fractionPart = cMoneyStringBuffer.substring(cMoneyStringBuffer.indexOf("."));

          cMoneyStringBuffer.delete(cMoneyStringBuffer.indexOf("."), cMoneyStringBuffer.length());

          while (cMoneyStringBuffer.indexOf("零拾") != -1) {

          cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零拾"), cMoneyStringBuffer.indexOf("零拾") + 2, ZERO);

          }

          while (cMoneyStringBuffer.indexOf("零佰") != -1) {

          cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零佰"), cMoneyStringBuffer.indexOf("零佰") + 2, ZERO);

          }

          while (cMoneyStringBuffer.indexOf("零仟") != -1) {

          cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零仟"), cMoneyStringBuffer.indexOf("零仟") + 2, ZERO);

          }

          while (cMoneyStringBuffer.indexOf("零萬") != -1) {

          cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零萬"), cMoneyStringBuffer.indexOf("零萬") + 2, TEN_THOUSAND);

          }

          while (cMoneyStringBuffer.indexOf("零億") != -1) {

          cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零億"), cMoneyStringBuffer.indexOf("零億") + 2, HUNDRED_MILLION);

          }

          while (cMoneyStringBuffer.indexOf("零零") != -1) {

          cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零零"), cMoneyStringBuffer.indexOf("零零") + 2, ZERO);

          }

          if (cMoneyStringBuffer.lastIndexOf(ZERO) == cMoneyStringBuffer.length() - 1)

          cMoneyStringBuffer.delete(cMoneyStringBuffer.length() - 1, cMoneyStringBuffer.length());

          cMoneyStringBuffer.append(fractionPart);

          result = cMoneyStringBuffer.toString();

          return result;

          }

          private String addUnitsToChineseMoneyString(String moneyStr) {  
          String result; StringBuffer cMoneyStringBuffer = new StringBuffer(moneyStr);
           int indexOfDot = cMoneyStringBuffer.indexOf(DOT);  
          cMoneyStringBuffer.replace(indexOfDot, indexOfDot + 1, YUAN);
          cMoneyStringBuffer.insert(cMoneyStringBuffer.length() - 1, JIAO);
          cMoneyStringBuffer.insert(cMoneyStringBuffer.length(), FEN);
           if (cMoneyStringBuffer.indexOf("零角零分") != -1)//沒有零頭,加整
            cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零角零分"), cMoneyStringBuffer.length(), "整");
          else  if (cMoneyStringBuffer.indexOf("零分") != -1)//沒有零分,加整   
          cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf("零分"), cMoneyStringBuffer.length(), "整");
           else { if(cMoneyStringBuffer.indexOf("零角")!=-1)
                  cMoneyStringBuffer.delete(cMoneyStringBuffer.indexOf("零角"),cMoneyStringBuffer.indexOf("零角")+2);
               cMoneyStringBuffer.append("整");
          }  
          result = cMoneyStringBuffer.toString();
          return result;
          }
          private void checkPrecision(String moneyStr) {
          int fractionDigits = moneyStr.length() - moneyStr.indexOf(DOT) - 1; 
           if (fractionDigits > 2)  throw new RuntimeException("金額" + moneyStr + "的小數位多于兩位。"); //精度不能比分低  
          }
          public static void main(String args[]) {  
          System.out.println(getInstance().format(new Double(10010001.01)));
          }
          }

          3、繼承時候類的執行順序問題,一般都是選擇題,問你將會打印出什么?
          答:父類: package test;
          public class FatherClass {
          public FatherClass() {
          System.out.println("FatherClass Create");
          }
          }
          子類: package test;
          import test.FatherClass;
          public class ChildClass extends FatherClass {
          public ChildClass() {
          System.out.println("ChildClass Create");
          }
          public static void main(String[] args) {
          FatherClass fc = new FatherClass();
          ChildClass cc = new ChildClass();
          }
          }
          輸出結果: C:>java test.ChildClass  FatherClass Create   FatherClass Create   ChildClass Create

          4、內部類的實現方式?
          答:示例代碼如下:
          package test;
          public class OuterClass {
          private class InterClass {
          public InterClass() {
          System.out.println("InterClass Create");
          }
          }
          public OuterClass() {
          InterClass ic = new InterClass();
          System.out.println("OuterClass Create");
          }
          public static void main(String[] args) {
          OuterClass oc = new OuterClass();
          }
          }
           輸出結果: C:>java test/OuterClass
          InterClass Create   OuterClass Create
          再一個例題:
          public class OuterClass {
           private double d1 = 1.0;
          //insert code here
          }
          You need to insert an inner class declaration at line 3. Which two inner class declarations are valid?(Choose two.)
          A. class InnerOne{ public static double methoda() {return d1;} }
          B. public class InnerOne{ static double methoda() {return d1;} }
          C. private class InnerOne{ double methoda() {return d1;} }
          D. static class InnerOne{ protected double methoda() {return d1;} }
          E. abstract class InnerOne{ public abstract double methoda(); }

          說明如下: 一.靜態內部類可以有靜態成員,而非靜態內部類則不能有靜態成員。 故 A、B 錯 二.靜態內部類的非靜態成員可以訪問外部類的靜態變量,而不可訪問外部類的非靜態變量;return d1 出錯。故 D 錯 三.非靜態內部類的非靜態成員可以訪問外部類的非靜態變量。 故 C 正確 四.答案為C、E

          5、Java 的通信編程,編程題(或問答),用JAVA SOCKET編程,讀服務器幾個字符,再寫入本地顯示?
          答:Server端程序:
          package test;
          import java.net.*;
          import java.io.*;
          public class Server {
          private ServerSocket ss;
          private Socket socket;
          private BufferedReader in;
          private PrintWriter out;
          public Server() {
          try {
          ss=new ServerSocket(10000);
          while(true) {
          socket = ss.accept();
          String RemoteIP = socket.getInetAddress().getHostAddress();
          String RemotePort = ":"+socket.getLocalPort();
          System.out.println("A client come in!IP:"+RemoteIP+RemotePort);
          in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
          String line = in.readLine();
          System.out.println("Cleint send is :" + line);
          out = new PrintWriter(socket.getOutputStream(),true);
          out.println("Your Message Received!");
          out.close();
          in.close();
          socket.close();
          }
          }catch (IOException e) {
          out.println("wrong");
          }
          }
          public static void main(String[] args) {
          new Server();
          }
          }
          Client端程序:
          package test; import java.io.*;
          import java.net.*;
          public class Client {
          Socket socket;
          BufferedReader in;
          PrintWriter out;
          public Client() {
          try {
          System.out.println("Try to Connect to 127.0.0.1:10000");
          socket = new Socket("127.0.0.1",10000);
          System.out.println("The Server Connected!");
          System.out.println("Please enter some Character:");
          BufferedReader line = new BufferedReader(new InputStreamReader(System.in));
          out = new PrintWriter(socket.getOutputStream(),true);
          Out

          6、 forward和rederect的區別
          答:redirect重定向到另外一個頁面,重新開始一個請求forward跳轉到另外一個頁面, 請求不斷開

          7、 jsp的常用的命令
          答:page, include, talib, forward,

          8、 接口和內部類、抽象類的特征
          答:接口:在一個類里,只有申明沒有實現。內部類:是在一個類的內部定義的一個類;抽象類:是以abstract 定義的,里面至少有一個抽象方法。

          9、 文件讀寫的基本類
          答:File Reader 類和FileWriter類分別繼承自Reader類和Writer類。FileReader類用于讀取文件,File Writer類用于將數據寫入文件,這兩各類在使用前,都必須要調用其構造方法創建相應的對象,然后調用相應的read()或 write()方法。

          10、 串行化的注意事項以及如何實現串行化
          答:如果有循環引用是不可以串行化的。對象輸出流的WriteObject方法和 對象輸入流的ReadObect 方法

          11、 線程的基本概念、線程的本狀態以及狀態之間的關系
          •新建 (Born) : 新建的線程處于新建狀態
          •就緒 (Ready) : 在創建線程后,它將處于就緒狀態,等待 start() 方法被調用
          •運行 (Running) : 線程在開始執行時進入運行狀態
          •睡眠 (Sleeping) : 線程的執行可通過使用 sleep() 方法來暫時中止。在睡眠后,線程將進入就緒狀態
          •等待 (Waiting) : 如果調用了 wait() 方法,線程將處于等待狀態。用于在兩個或多個線程并發運行時。
          •掛起 (Suspended) : 在臨時停止或中斷線程的執行時,線程就處于掛起狀態。
          •恢復 (Resume) : 在掛起的線程被恢復執行時,可以說它已被恢復。
          •阻塞 (Blocked) – 在線程等待一個事件時(例如輸入/輸出操作),就稱其處于阻塞狀態。
          •死亡 (Dead) – 在 run() 方法已完成執行或其 stop() 方法被調用之后,線程就處于死亡狀態。
           
          12、 線程的同步、如何實現線程的同步
          答:當兩個或多個線程同時訪問同一個變量,并且以個線程需要修改這個變量。就要用到線程同步。在Java 中,同步是通過 synchronized 關鍵字來定義的。 諾是想同步化某程序段,可以使用 synchronized(object){}方法,其中{}內的程序語句被同步化。

          13、 socket通信(tcp/udp區別及JAVA的實現方式)
          TCP——傳輸控制協議,具有極高的可靠性,保證數據包按照順序準確到達,但其也有著很高的額外負擔。
          UDP——使用者數據元協議,并不能保證數據包會被成功的送達,也不保證數據包到達的順序,但其傳輸速度很快。大多數我們會使用TCP,偶爾才會動用UDP,如聲音訊號,即使少量遺失,也無關緊要。

          14、 JAVA的事件委托機制和垃圾回收機制
          java 事件委托機制的概念,一個源產生一個事件并將它送到一個或多個監聽器那里。在這種方案中,監聽器簡單的等待,直到它收到一個事件。一旦事件被接受,監聽器將處理這個事件,然后返回。垃圾回收機制 垃圾收集是將分配給對象但不在使用的內存回收或釋放的過程。如果一個對象沒有指向它的引用或者其賦值為null,則次對象適合進行垃圾回收

          15、 JDBC調用數據庫的基本步驟
          導入必要的類,裝入JDBC驅動程序,識別數據源,分配一個Connection對象,分配一個Statement對象,使用Statement執行一個查詢,從返回的ResultSet對象中檢索數據,關閉ResultSet,關閉Statement對象,關閉Connection對象

          16、 解析XML文件的幾種方式和區別
          答:Dom解析 在內存中創建一個DOM樹,能隨機訪問文件內容,也可以修改原文件內容SAX解析 線性解析,不能隨機訪問,也無法修改原文件Dom解析要先用SAX解析創建DOM樹

          17、 JAVA的四種基本權限的定義public private protected 默認

          18、 JAVA的國際化  
          答:Java 中提供了諾干國際化明感類,來實現國際化的。例如:dateformat  timezone 等等。

          posted on 2006-11-16 12:20 lbfeng 閱讀(249) 評論(0)  編輯  收藏 所屬分類: 專業考試題庫
          主站蜘蛛池模板: 绥德县| 湖南省| 云南省| 栾城县| 泗阳县| 西青区| 镇宁| 佛冈县| 莱西市| 石首市| 绥江县| 北安市| 石狮市| 昭平县| 东城区| 白沙| 呼玛县| 宿迁市| 昌黎县| 永宁县| 深州市| 高碑店市| 鹤岗市| 九龙城区| 屏边| 杭州市| 黄陵县| 洛川县| 遂昌县| 都安| 洛宁县| 温州市| 黄平县| 赤城县| 随州市| 清涧县| 若羌县| 多伦县| 桦南县| 交口县| 太谷县|