dream-in-fly
          路上...
          posts - 31,  comments - 6,  trackbacks - 0
          在遙遠古希臘的大草原中,馳騁著一批半人半馬的族群,這是一個生性兇猛的族群。“半人半馬”代表著理性與非理性、人性與獸性間的矛盾掙扎,這就是人馬部落。部落里唯一的例外射手奇倫,是一個生性善良的男子,他對人坦誠真摯,謙遜有理。因此受到大家的尊敬與愛戴。

            有一天,英雄赫五力來拜訪他的朋友奇倫。赫五力早就聽說人馬族的酒香醇無比,便要求奇倫給他拿來享用,可是,他喝光了奇倫的酒仍不盡興,執意要喝光全部落的酒。奇倫非常耐心地解釋給他聽,酒是部落的公共財產,不是任何一個人可以獨自占有的,希望赫五力不要因為一時的興致而犯眾怒。赫五力向來脾氣暴躁,怎么能聽得進奇倫的話,他把這個善良的朋友推到一邊就闖進了人馬部落。果不出奇倫所料,暴躁的赫五力和兇猛的人馬族碰在一起,沖突不可避免的發生了。

            赫五力力大無窮,幼年即用雙手扼死巨蟒,他完成國王的十項不可能完成的任務都游刃有余,連太陽神阿波羅都懼他三分,人馬族雖然厲害,也并不是赫五力的對手,他們紛紛落逃。赫五力手持神弓緊緊追趕,借著酒勁,大肆進攻。人馬族被逼的走投無路,只好逃到了奇倫的家中。人們惶惶不安,赫五力站在門口大聲呵斥,如果再沒人出來,他就把這個部落毀掉。奇倫聽到這里,為了部落,為了朋友,為了化解這場爭斗,他奮不顧身的推開門,走了出來。就在那一剎那,赫五力的箭也飛了過來!赫五力惋惜又痛心的看著自己的朋友被神箭射穿心臟,而奇倫則用盡最后的力氣說到:“再鋒利的箭也會被軟弱的心包容;再瘋狂的獸性也不會泯滅人性。”

            這時候,奇倫的身體碎成了無數的小星星,飛到了天上,它們聚集在一起,好象人馬的樣子,那只箭還似乎就在他的胸前。為了紀念善良的奇倫,人們就管這個星座叫射手座。

          posted @ 2005-04-17 22:09 小毅 閱讀(196) | 評論 (0)編輯 收藏
          從嘉興回來...兄弟沒變多少 呵呵 一樣的忙

          認識了挺多的朋友 松哥,東哥,CEO,死過妹妹....

          雖然前幾天的筆試并沒有成功  心情并不怎么好  在嘉興卻還是呆的開心的...^ ^


          每次去看兄弟都能學到好多...
          剛好碰上他在開發寵物系統...php-asp...
          學了很多東西 有些習慣他好象是于身具來的  大概這就是天賦吧....


          4月中旬了  畢業了近了...
          工作還沒定  心理有點煩了....
          posted @ 2005-04-15 20:41 小毅 閱讀(169) | 評論 (0)編輯 收藏
          作者:xm4014

          今天開始學習Java中多線程的實現.

            線程是一些可以并行的,獨立的執行的代碼.之前我編的程序都只能做一件事情,也就是只有一個線程.多線程的編程就是可以將程序任務分成多個并行的子任務,同時運行,互不干擾.我對多線程的理解是從格斗游戲得來的.格斗游戲中兩人對打就是通過兩個線程來實現的吧,否則如何能夠你出你的招,我發我的沖擊波呢.

            (1月18日)突然想到一個問題,補充一下.多線程是不是我們通常所說的多任務呢?我的理解是,不能這樣說也可以這樣說.

            簡單說來,多線程提供了一種在進程內部進行多個線程并行調度的機制,而多任務則提供的是在一個操作系統內部運行多個進程的機制.

            多任務操作系統(如Windows)的基本原理是這樣的:操作系統將CPU的時間片分配給多個線程,每個線程在操作系統指定的時間片內完成(注意,這里的多個線程是分屬于不同進程的).操作系統不斷的從一個線程的執行切換到另一個線程的執行,如此往復,宏觀上看來,就好像是多個線程在一起執行.由于這多個線程分屬于不同的進程,因此在我們看來,就好像是多個進程在同時執行,這樣就實現了多任務.Whoops,真繞口.

            如上,多線程和多任務是有很明顯的區別的.但是再想一下,在一個應用程序內實現多線程不也是靠CPU分配時間片嗎?既然原理是相同的,那么多線程也可以說是多任務的.

            一個Java程序啟動后,就已經有一個線程在運行,我們可以通過下面的例子來初步建立一個線程的實際印象

          class testthread{
          public static void main(String args[]){
          Thread t=Thread.currentThread();
          t.setName("This Thread is running");
          System.out.println("The running thead:"+t);
          try{
          for(int i=0;i<5;i++)
          {
          System.out.println("Sleep time"+i);
          Thread.sleep(1000);//掛起線程,就是讓線程休息一會兒,
          //不占用系統資源,因此其它線程可以繼續.
          //這里的Thread缺省表示主線程
          }
          }catch(InterruptedException e){System.out.println("thread has wrong");}
          }
          }

            這只是一個線程,那么我們怎么實現多個線程呢?又怎樣讓線程做我安排它要做的事情呢?

            實現線程體的構造有兩種方法.

            第一種方法是通過繼承構造線程體.

            在Java中專門有一個Thread類,這個類里面有一個函數run(),里面記錄著線程要完成的操作,就好像通常所說的主函數main()一樣,run()函數運行完了,線程就結束了.通過繼承這個類,我們可以定義我們自己的線程,在run函數中告訴它該做什么事情.下面的程序就是繼承了一個SimpleThread類,用兩個線程來輸出HelloWorld.

          public class TwoThread{

          public static void main(String args[]){
          new SimpleThread("HelloWorld1").start();//創建兩個線程的實例,就這么簡單
          new SimpleThread("HelloWorld2").start();
          }

          }
          class SimpleThread extends Thread{ file://真正的內容在這里
          public SimpleThread(String str){
          super(str);//super代表SimpleThread類的直接父類,這里就是Thread
          }

          file://我們要線程做的事情都在這里了
          public void run(){
          for(int i=0;i<10;i++){
          System.out.println(i+" "+getName());
          try{
          sleep((int)(Math.random()*1000));
          }catch(InterruptedException e){}
          }
          System.out.println("Done!"+getName());
          }
          }

            運行的結果是兩個線程交替顯示各自的HelloWorld十次,輸出是混在一起的,因為兩個線程是同時運行的.

          posted @ 2005-04-01 20:30 小毅 閱讀(207) | 評論 (0)編輯 收藏

          作者:xm4014


            今天第一次接觸Java。

            雖然以前間或的也看了些書籍,但多是隔靴搔癢,上不了正席,絕不敢說自己懂Java。接觸一門新的技術和初戀一樣,都是第一次,但不同的是后者一般開始無比甜蜜,結局卻很痛苦,而前者則往往開始很痛苦,越到后來卻越是有味,簡直是欲罷不能.現在我就正處于這個很痛苦的階段,連一個最簡單的Helloworld都運行不出來,總是提示Excepion in thread "main" java.lan.NoClassDefFoundError. 只好上網去查,去搜.記性又不好,所以搜出來趕緊保存下來,常備無患.

            一般來說安裝完JDK之后,一定要按一下步驟配置,才可正確編譯運行(假定jdk版本為1.4.0)

            1.將jdk1.4.0-安裝在自己機器的某個盤符的根目錄下,如:可安裝在C:\jdk下。

            ***(以下出現的c:\jdk改為你自己安裝JDK的目錄)***

            2.如果你的運行環境是win98,則在C盤根目錄下,autoexec.bat文件中,加入下面兩條語句:

            set Path=%PATH%;c:\jdk\bin

            set CLASSPATH=.;c:\jdk\lib\dt.jar;c:\jdk\lib\tools.jar

            保存后,重新啟動機器,就完成了jdk1.4的安裝。

            3.如果你的運行環境是win2000的話,則需在“控制面板”的“系統”下,“高級”選項的“環境變量”中,添加兩個用戶變量。

            其中一個用戶變量的名稱為“path”,值為“.;d:\j2sdk1.4.0_01\bin”,

            另一個用戶變量的名稱為"CLASSPATH",值為“.;d"\j2sdk1.4.0_01\lib\dt.jar;d:\j2sdk1.4.0_01\lib\tools.jar”,單擊“確定”即可。即完成了jdk1.4.0的安裝。

            至于這樣做的意義何在,我想應該是讓Java系統在編譯字節代碼(.java)的時候需要一個什么東東的支持,如果你不告訴它這個東東放在哪個地方的話,它就犯傻了?!

            看到屏幕上終于顯示出Hello world對我來說意義重大.這是我近一年來寫的第一個程序!再次踏上程序之路,簡直有恍如隔世的感覺,已經快找不準我的位置了.還好原來學的一些關于C++和面向對象的皮毛沒忘光光,所以費點周折熟悉了JDK的環境之后,接下來的事情就好辦多了,心里也踏實多了.

            用String類直接定義字符串變量比起C中討厭的指針,感覺確實好的多,用慣了Object Pascal的我,如果再回去數* *,真要瘋掉不可.

            數組的定義和C,C++好像略有不同,記不清了,先記下來再說

            int[] number=new int[5]

            String[] message=new String[5]

            變量這一部分想起來要交待的也就這么多吧。雖然是菜鳥,但我也知道,總是如譚浩強般在語法上面死摳的人簡直是白癡:大多數情況下,漂亮的程序根本不需要無謂的點綴,工工整整,思路清晰就可以了.

            倒是對于Java程序的框架我倒想備忘一下,一個簡單的java程序好像是應該是這樣的框架

           class ProgramName
          {
          public static void main(String[] args)
          {
          file://程序的主體
          }
          public static int othermethod()
          {
          file://其它方法
          }
          }

            整個程序在一個大的類中,這個類的概念應該就跟pascal里面的單元差不多的。同pascal一樣,文件名也要與單元名-在這里是類名-一樣.Java對大小寫要求的非常嚴格,我語法錯了好幾次都是因為這個.

            Java程序就是由一個或者多個或者很多個方法在這樣一個大類當中組成的.

            在如上的代碼中,定義方法的參數表示的意思分別為:

            public表示此成員函數是公有的,可以被其他類直接調用

            static表示main成員函數在ProgramName類的所有對象中是唯一的,Java將為其分配永久存儲空間

          posted @ 2005-04-01 20:18 小毅 閱讀(231) | 評論 (0)編輯 收藏
          過幾天要去東星軟件筆試程序員,要求挺高的 網上找了篇筆試的文章

          前段時間因為要參加一個筆試,在準備期間在網上找到了兩條關于筆試題目的文章,其中一篇為<<有感:應聘Java筆試時可能出現問題>>,還有一篇忘了名字,讀后深受啟發。
          ??????? 在尋找這些答案的過程中,我將相關答案記錄下來,就形成了以下這些東西。需要說明的是以下答案肯定有很多不完整甚至錯誤的地方,需要各位來更正與完善它,千萬不要扔我的雞蛋啊。
          ?????? 希望本文能夠給即將奔赴筆試考場的同仁些許幫助,更希望更多的人加入到收集整理筆試題與完善答案的這些工作中來,為大家更好的獲得工作機會做一點貢獻。
          ?????? 在此感謝前面兩文的作者的對筆試題目的收集與整理。
          ?????? 如有任何意見與建議請通過QQ:6045306,Mail:huijunzi@21cn.com與我聯系。

          Java基礎方面:

          1、作用域public,private,protected,以及不寫時的區別
          答:區別如下:
          作用域?????????? 當前類?????? 同一package? 子孫類?????? 其他package
          public??????????? √????????????? √????????????????? √???????????? √
          protected??????? √????????????? √????????????????? √???????????? ×
          friendly????????? √????????????? √?????????????????? ×??????????? ×
          private?????????? √????????????? ×?????????????????? ×??????????? ×
          不寫時默認為friendly

          2、ArrayList和Vector的區別,HashMap和Hashtable的區別
          答:
          就ArrayList與Vector主要從二方面來說.
          一.同步性:Vector是線程安全的,也就是說是同步的,而ArrayList是線程序不安全的,不是同步的
          二.數據增長:當需要增長時,Vector默認增長為原來一培,而ArrayList卻是原來的一半
          就HashMap與HashTable主要從三方面來說。
          一.歷史原因:Hashtable是基于陳舊的Dictionary類的,HashMap是Java 1.2引進的Map接口的一個實現
          二.同步性:Hashtable是線程安全的,也就是說是同步的,而HashMap是線程序不安全的,不是同步的
          三.值:只有HashMap可以讓你將空值作為一個表的條目的key或value

          3、char型變量中能不能存貯一個中文漢字?為什么?
          答:
          是能夠定義成為一個中文的,因為java中以unicode編碼,一個char占16個字節,所以放一個中文是沒問題的

          4、多線程有幾種實現方法,都是什么?同步有幾種實現方法,都是什么?
          答:
          多線程有兩種實現方法,分別是繼承Thread類與實現Runnable接口
          同步的實現方面有兩種,分別是synchronized,wait與notify

          5、繼承時候類的執行順序問題,一般都是選擇題,問你將會打印出什么?
          答:
          父類:
          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

          6、內部類的實現方式?
          答:
          示例代碼如下:
          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

          7、垃圾回收機制,如何優化程序?
          希望大家補上,謝謝

          8、float型float f=3.4是否正確?
          答:
          不正確。精度不準確,應該用強制類型轉換,如下所示:float f=(float)3.4

          9、介紹JAVA中的Collection FrameWork(包括如何寫自己的數據結構)?
          答:
          Collection FrameWork如下:
          Collection
          ├List
          │├LinkedList
          │├ArrayList
          │└Vector
          │ └Stack
          └Set
          Map
          ├Hashtable
          ├HashMap
          └WeakHashMap
          Collection是最基本的集合接口,一個Collection代表一組Object,即Collection的元素(Elements)
          Map提供key到value的映射

          10、Java中異常處理機制,事件機制?

          11、JAVA中的多形與繼承?
          希望大家補上,謝謝

          12、抽象類與接口?
          答:
          抽象類與接口都用于抽象,但是抽象類(JAVA中)可以有自己的部分實現,而接口則完全是一個標識(同時有多重繼承的功能)。

          13、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.println(line.readLine());
          ???in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
          ???System.out.println(in.readLine());
          ???out.close();
          ???in.close();
          ???socket.close();
          ??}catch(IOException e)
          ??{
          ???out.println("Wrong");
          ??}
          ?}
          ?public static void main(String[] args)
          ?{
          ??new Client();
          ?}
          };

          14、用JAVA實現一種排序,JAVA類實現序列化的方法(二種)? 如在COLLECTION框架中,實現比較要實現什么樣的接口?
          答:
          用插入法進行排序代碼如下
          package test;
          import java.util.*;
          class? InsertSort
          {
          ?ArrayList al;
          ?public InsertSort(int num,int mod)
          ?{
          ??al = new ArrayList(num);
          ??Random rand = new Random();
          ??System.out.println("The ArrayList Sort Before:");
          ??for (int i=0;i??{
          ???al.add(new Integer(Math.abs(rand.nextInt()) % mod + 1));
          ???System.out.println("al["+i+"]="+al.get(i));
          ??}
          ?}
          ?public void SortIt()
          ?{
          ??Integer tempInt;
          ??int MaxSize=1;
          ??for(int i=1;i??{
          ?????? tempInt = (Integer)al.remove(i);
          ????if(tempInt.intValue()>=((Integer)al.get(MaxSize-1)).intValue())
          ????{
          ?????al.add(MaxSize,tempInt);
          ?????MaxSize++;
          ?????System.out.println(al.toString());
          ????} else {
          ?????for (int j=0;j?????{
          ??????if

          (((Integer)al.get(j)).intValue()>=tempInt.intValue())
          ??????{
          ???????al.add(j,tempInt);
          ???????MaxSize++;
          ???????System.out.println(al.toString());
          ???????break;
          ??????}
          ?????}
          ????}
          ??}
          ??System.out.println("The ArrayList Sort After:");
          ??for(int i=0;i??{
          ???System.out.println("al["+i+"]="+al.get(i));
          ??}
          ?}
          ?public static void main(String[] args)
          ?{
          ??InsertSort is = new InsertSort(10,100);
          ??is.SortIt();
          ?}
          }
          JAVA類實現序例化的方法是實現java.io.Serializable接口
          Collection框架中實現比較要實現Comparable 接口和 Comparator 接口

          15、編程:編寫一個截取字符串的函數,輸入為一個字符串和字節數,輸出為按字節截取的字符串。 但是要保證漢字不被截半個,如“我ABC”4,應該截為“我AB”,輸入“我ABC漢DEF”,6,應該輸出為“我ABC”而不是“我ABC+漢的半個”。
          答:
          代碼如下:
          package test;

          class? SplitString
          {
          ?String SplitStr;
          ?int SplitByte;
          ?public SplitString(String str,int bytes)
          ?{
          ??SplitStr=str;
          ??SplitByte=bytes;
          ??System.out.println("The String is:'"+SplitStr+"';SplitBytes="+SplitByte);
          ?}
          ?public void SplitIt()
          ?{
          ??int loopCount;
          ??

          loopCount=(SplitStr.length()%SplitByte==0)?(SplitStr.length()/SplitByte):(SplitStr.length()/Split

          Byte+1);
          ??System.out.println("Will Split into "+loopCount);
          ??for (int i=1;i<=loopCount ;i++ )
          ??{
          ???if (i==loopCount){
          ????

          System.out.println(SplitStr.substring((i-1)*SplitByte,SplitStr.length()));
          ???} else {
          ????

          System.out.println(SplitStr.substring((i-1)*SplitByte,(i*SplitByte)));
          ???}
          ??}
          ?}
          ?public static void main(String[] args)
          ?{
          ??SplitString ss = new SplitString("test中dd文dsaf中男大3443n中國43中國人

          0ewldfls=103",4);
          ??ss.SplitIt();
          ?}
          }

          16、JAVA多線程編程。 用JAVA寫一個多線程程序,如寫四個線程,二個加1,二個對一個變量減一,輸出。
          希望大家補上,謝謝

          17、STRING與STRINGBUFFER的區別。
          答:
          STRING的長度是不可變的,STRINGBUFFER的長度是可變的。如果你對字符串中的內容經常進行操作,特別是內容要修改時,那么使用StringBuffer,如果最后需要String,那么使用StringBuffer的toString()方法

          Jsp方面

          1、jsp有哪些內置對象?作用分別是什么?
          答:
          JSP共有以下9種基本內置組件(可與ASP的6種內部組件相對應):
           request 用戶端請求,此請求會包含來自GET/POST請求的參數
          ?? response 網頁傳回用戶端的回應
          ?? pageContext 網頁的屬性是在這里管理
          ?? session 與請求有關的會話期
          ?? application servlet 正在執行的內容
          ?? out 用來傳送回應的輸出
          ?? config servlet的構架部件
          ?? page JSP網頁本身
          ?? exception 針對錯誤網頁,未捕捉的例外

          2、jsp有哪些動作?作用分別是什么?
          答:
          JSP共有以下6種基本動作
          ?? jsp:include:在頁面被請求的時候引入一個文件。
          ?? jsp:useBean:尋找或者實例化一個JavaBean。
          ?? jsp:setProperty:設置JavaBean的屬性。
          ?? jsp:getProperty:輸出某個JavaBean的屬性。
          ?? jsp:forward:把請求轉到一個新的頁面。
          ?? jsp:plugin:根據瀏覽器類型為Java插件生成OBJECT或EMBED標記

          3、JSP中動態INCLUDE與靜態INCLUDE的區別?
          答:
          動態INCLUDE用jsp:include動作實現
          ?? 它總是會檢查所含文件中的變化,適合用于包含動態頁面,并且可以帶參數
          ?? 靜態INCLUDE用include偽碼實現,定不會檢查所含文件的變化,適用于包含靜態頁面
          ?? <%@ include file="included.htm" %>

          4、兩種跳轉方式分別是什么?有什么區別?
          答:
          有兩種,分別為:
          ?

          ?
          ? 前者頁面不會轉向include所指的頁面,只是顯示該頁的結果,主頁面還是原來的頁面。執行完后還會回來,相當于函數調用。并且可以帶參數.后者完全轉向新頁面,不會再回來。相當于go to 語句。

          Servlet方面

          1、說一說Servlet的生命周期?
          答:
          servlet有良好的生存期的定義,包括加載和實例化、初始化、處理請求以及服務結束。這個生存期由javax.servlet.Servlet接口的init,service和destroy方法表達。

          2、Servlet版本間(忘了問的是哪兩個版本了)的不同?
          希望大家補上,謝謝

          3、JAVA SERVLET API中forward() 與redirect()的區別?
          答:
          前者僅是容器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向后的地址;后者則是完全的跳轉,瀏覽器將會得到跳轉的地址,并重新發送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉后的鏈接地址。所以,前者更加高效,在前者可以滿足需要時,盡量使用forward()方法,并且,這樣也有助于隱藏實際的鏈接。在有些情況下,比如,需要跳轉到一個其它服務器上的資源,則必須使用sendRedirect()方法。

          4、Servlet的基本架構
          public class ServletName extends HttpServlet {
          ? public void doPost(HttpServletRequest request, HttpServletResponse response) throws
          ????? ServletException, IOException? {
          ????? }
          ? public void doGet(HttpServletRequest request, HttpServletResponse response) throws
          ????? ServletException, IOException? {
          ????? }
          }

          Jdbc、Jdo方面

          1、可能會讓你寫一段Jdbc連Oracle的程序,并實現數據查詢.
          答:
          程序如下:
          package hello.ant;
          import java.sql.*;
          public class? jdbc
          {
          ?String dbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl";
          ?String theUser="admin";
          ?String thePw="manager";
          ?Connection c=null;
          ?Statement conn;
          ?ResultSet rs=null;
          ?public jdbc()
          ?{
          ??try{
          ??? Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
          ????????? c = DriverManager.getConnection(dbUrl,theUser,thePw);
          ??? conn=c.createStatement();
          ??}catch(Exception e){
          ???e.printStackTrace();
          ??}
          ?}
          ?public boolean executeUpdate(String sql)
          ?{
          ???try
          ???{
          ?????conn.executeUpdate(sql);
          ?????return true;
          ???}
          ???catch (SQLException e)
          ???{
          ?????e.printStackTrace();
          ?????return false;
          ???}
          ?}
          ?public ResultSet executeQuery(String sql)
          ?{
          ???rs=null;
          ???try
          ???{
          ?????rs=conn.executeQuery(sql);
          ???}
          ???catch (SQLException e)
          ???{
          ?????e.printStackTrace();
          ???}
          ???return rs;
          ?}
          ?public void close()
          ?{
          ???try
          ???{
          ?????conn.close();
          ?????c.close();
          ???}
          ???catch (Exception e)
          ???{
          ?????e.printStackTrace();
          ???}
          ?}
          ?public static void main(String[] args)
          ?{
          ??ResultSet rs;
          ??jdbc conn = new jdbc();
          ??rs=conn.executeQuery("select * from test");
          ??try{
          ??while (rs.next())
          ??{
          ???System.out.println(rs.getString("id"));
          ???System.out.println(rs.getString("name"));
          ??}
          ??}catch(Exception e)
          ??{
          ???e.printStackTrace();
          ??}
          ?}
          }

          2、Class.forName的作用?為什么要用?
          答:
          調用該訪問返回一個以字符串指定類名的類的對象。

          3、Jdo是什么?
          答:
          JDO是Java對象持久化的新的規范,為java data object的簡稱,也是一個用于存取某種數據倉庫中的對象的標準化API。JDO提供了透明的對象存儲,因此對開發人員來說,存儲數據對象完全不需要額外的代碼(如JDBC API的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發人員解脫出來,從而集中時間和精力在業務邏輯上。另外,JDO很靈活,因為它可以在任何數據底層上運行。JDBC只是面向關系數據庫(RDBMS)JDO更通用,提供到任何數據底層的存儲功能,比如關系數據庫、文件、XML以及對象數據庫(ODBMS)等等,使得應用可移植性更強。

          4、在ORACLE大數據量下的分頁解決方法。一般用截取ID方法,還有是三層嵌套方法。
          答:
          一種分頁方法
          <%
          ? int i=1;
          ? int numPages=14;
          ? String pages = request.getParameter("page") ;
          ? int currentPage = 1;
          ? currentPage=(pages==null)?(1):{Integer.parseInt(pages)}
          ? sql = "select count(*) from tables";
          ? ResultSet rs = DBLink.executeQuery(sql) ;
          ? while(rs.next()) i = rs.getInt(1) ;
          ? int intPageCount=1;
          ? intPageCount=(i%numPages==0)?(i/numPages):(i/numPages+1);
          ? int nextPage ;
          ? int upPage;
          ? nextPage = currentPage+1;
          ? if (nextPage>=intPageCount) nextPage=intPageCount;
          ? upPage = currentPage-1;
          ? if (upPage<=1) upPage=1;
          ? rs.close();
          ? sql="select * from tables";
          ? rs=DBLink.executeQuery(sql);
          ? i=0;
          ? while((i%>
          //輸出內容
          //輸出翻頁連接
          合計:<%=currentPage%>/<%=intPageCount%>
          第一頁

          href="List.jsp?page=<%=upPage%>">上一頁
          <%
          ? for(int j=1;j<=intPageCount;j++){
          ? if(currentPage!=j){
          %>
          ? [<%=j%>]
          <%
          ? }else{
          ? out.println(j);
          ? }
          ? }
          %>
          下一頁最后頁


          Xml方面

          1、xml有哪些解析技術?區別是什么?
          答:
          有DOM,SAX,STAX等
          DOM:處理大型文件時其性能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構占用的內存較多,而且DOM必須在解析文件之前把整個文檔裝入內存,適合對XML的隨機訪問SAX:不現于DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML文件,不需要一次全部裝載整個文件。當遇到像文件開頭,文檔結束,或者標簽開頭與標簽結束時,它會觸發一個事件,用戶通過在其回調事件中寫入處理代碼來處理XML文件,適合對XML的順序訪問
          STAX:Streaming API for XML (StAX)

          2、你在項目中用到了xml技術的哪些方面?如何實現的?
          答:
          用到了數據存貯,信息配置兩方面。在做數據交換平臺時,將不能數據源的數據組裝成XML文件,然后將XML文件壓縮打包加密后通過網絡傳送給接收者,接收解密與解壓縮后再同XML文件中還原相關信息進行處理。在做軟件配置時,利用XML可以很方便的進行,軟件的各種配置參數都存貯在XML文件中。

          3、用jdom解析xml文件時如何解決中文問題?如何解析?
          答:
          看如下代碼,用編碼方式加以解決
          package test;
          import java.io.*;
          public class DOMTest
          {
          ?private String inFile = "c:\\people.xml";
          ?private String outFile = "c:\\people.xml";?
          ?public static void main(String args[])
          ?{
          ??? ?new DOMTest();
          ??? }
          ?public DOMTest()
          ?{
          ??try
          ???? {?
          ???? ?javax.xml.parsers.DocumentBuilder builder =
          ???? ??

          javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();
          ???? ?org.w3c.dom.Document doc = builder.newDocument();
          ???? ?org.w3c.dom.Element root = doc.createElement("老師");
          ???? ?org.w3c.dom.Element wang = doc.createElement("王");
          ???org.w3c.dom.Element liu = doc.createElement("劉");
          ???? ?wang.appendChild(doc.createTextNode("我是王老師"));
          ???? ?root.appendChild(wang);
          ???? ?doc.appendChild(root);
          ???? ?javax.xml.transform.Transformer transformer =
          ???? ??javax.xml.transform.TransformerFactory.newInstance().newTransformer();
          ???? ?transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING, "gb2312");
          ???? ?transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT, "yes");??

          ? ?
          ???? ?transformer.transform(new javax.xml.transform.dom.DOMSource(doc),
          ???? ???????new

          javax.xml.transform.stream.StreamResult(outFile));
          ???? }
          ???? catch (Exception e)
          ???? {
          ???? ?System.out.println (e.getMessage());
          ???? }
          ??? }
          }

          4、編程用JAVA解析XML的方式.
          答:
          用SAX方式解析XML,XML文件如下:


          ? 王小明
          ? 信息學院??
          ? 6258113
          ? 男,1955年生,博士,95年調入海南大學
          ?

          ?事件回調類SAXHandler.java
          ?import java.io.*;
          import java.util.Hashtable;
          import org.xml.sax.*;
          public class SAXHandler extends HandlerBase
          ? {
          ? private Hashtable table = new Hashtable();
          ? private String currentElement = null;
          ? private String currentValue = null;
          ? public void setTable(Hashtable table)
          ??? {
          ??? this.table = table;
          ??? }
          ? public Hashtable getTable()
          ??? {
          ??? return table;
          ??? }
          ? public void startElement(String tag, AttributeList attrs)
          ? throws SAXException
          ??? {
          ??? currentElement = tag;
          ??? }
          ? public void characters(char[] ch, int start, int length)
          ? throws SAXException
          ??? {
          ??? currentValue = new String(ch, start, length);
          ??? }
          ? public void endElement(String name) throws SAXException
          ??? {
          ??? if (currentElement.equals(name))
          ????? table.put(currentElement, currentValue);
          ??? }
          ? }
          JSP內容顯示源碼,SaxXml.jsp:





          <%@ page errorPage="ErrPage.jsp"
          contentType="text/html;charset=GB2312" %>
          <%@ page import="java.io.*" %>
          <%@ page import="java.util.Hashtable" %>
          <%@ page import="org.w3c.dom.*" %>
          <%@ page import="org.xml.sax.*" %>
          <%@ page import="javax.xml.parsers.SAXParserFactory" %>
          <%@ page import="javax.xml.parsers.SAXParser" %>
          <%@ page import="SAXHandler" %>
          <%
          File file = new File("c:\\people.xml");
          FileReader reader = new FileReader(file);
          Parser parser;
          SAXParserFactory spf = SAXParserFactory.newInstance();
          SAXParser sp = spf.newSAXParser();
          SAXHandler handler = new SAXHandler();
          sp.parse(new InputSource(reader), handler);
          Hashtable hashTable = handler.getTable();
          out.println("");
          out.println("" + "");
          out.println("" + "");
          out.println("" + "");
          out.println("" + "");
          out.println("
          教師信息表
          姓名" +
          ? (String)hashTable.get(new String("name")) + "
          學院" +
          ? (String)hashTable.get(new String("college"))+"
          電話" +
          ? (String)hashTable.get(new String("telephone")) + "
          備注" +
          ? (String)hashTable.get(new String("notes")) + "
          ");
          %>

          EJB方面

          1、EJB2.0有哪些內容?分別用在什么場合? EJB2.0和EJB1.1的區別?
          答:
          規范內容包括Bean提供者,應用程序裝配者,EJB容器,EJB配置工具,EJB服務提供者,系統管理員。這里面,EJB容器是EJB之所以能夠運行的核心。EJB容器管理著EJB的創建,撤消,激活,去活,與數據庫的連接等等重要的核心工作。JSP,Servlet,EJB,JNDI,JDBC,JMS.....

          2、EJB與JAVA BEAN的區別?
          答:
          Java Bean 是可復用的組件,對Java Bean并沒有嚴格的規范,理論上講,任何一個Java類都可以是一個Bean。但通常情況下,由于Java Bean是被容器所創建(如Tomcat)的,所以Java Bean應具有一個無參的構造器,另外,通常Java Bean還要實現Serializable接口用于實現Bean的持久性。Java Bean實際上相當于微軟COM模型中的本地進程內COM組件,它是不能被跨進程訪問的。Enterprise Java Bean 相當于DCOM,即分布式組件。它是基于Java的遠程方法調用(RMI)技術的,所以EJB可以被遠程訪問(跨進程、跨計算機)。但EJB必須被布署在諸如Webspere、WebLogic這樣的容器中,EJB客戶從不直接訪問真正的EJB組件,而是通過其容器訪問。EJB容器是EJB組件的代理,EJB組件由容器所創建和管理。客戶通過容器來訪問真正的EJB組件。

          3、EJB的基本架構
          答:
          一個EJB包括三個部分:
          ? Remote Interface 接口的代碼
          ? package Beans;
          ? import javax.ejb.EJBObject;
          ? import java.rmi.RemoteException;
          ? public interface Add extends EJBObject
          ? {
          ?? //some method declare
          ? }
          ? Home Interface 接口的代碼
          ? package Beans;
          ? import java.rmi.RemoteException;
          ? import jaax.ejb.CreateException;
          ? import javax.ejb.EJBHome;
          ? public interface AddHome extends EJBHome
          ? {
          ??? //some method declare
          ? }
          ? EJB類的代碼
          ? package Beans;
          ? import java.rmi.RemoteException;
          ? import javax.ejb.SessionBean;
          ? import javx.ejb.SessionContext;
          ? public class AddBean Implements SessionBean
          ? {
          ??? //some method declare
          ? }?

          J2EE,MVC方面

          1、MVC的各個部分都有那些技術來實現?如何實現?
          答:
          MVC是Model-View-Controller的簡寫。"Model" 代表的是應用的業務邏輯(通過JavaBean,EJB組件實現), "View" 是應用的表示面(由JSP頁面產生),"Controller" 是提供應用的處理過程控制(一般是一個Servlet),通過這種設計模型把應用邏輯,處理過程和顯示邏輯分成不同的組件實現。這些組件可以進行交互和重用。

          2、應用服務器與WEB SERVER的區別?
          希望大家補上,謝謝


          3、J2EE是什么?
          答:
          Je22是Sun公司提出的多層(multi-diered),分布式(distributed),基于組件(component-base)的企業級應用模型(enterpriese application model).在這樣的一個應用系統中,可按照功能劃分為不同的組件,這些組件又可在不同計算機上,并且處于相應的層次(tier)中。所屬層次包括客戶層(clietn tier)組件,web層和組件,Business層和組件,企業信息系統(EIS)層。

          4、WEB SERVICE名詞解釋。JSWDL開發包的介紹。JAXP、JAXM的解釋。SOAP、UDDI,WSDL解釋。
          答:
          Web Service描述語言WSDL
          SOAP即簡單對象訪問協議(Simple Object Access Protocol),它是用于交換XML編碼信息的輕量級協議。
          UDDI 的目的是為電子商務建立標準;UDDI是一套基于Web的、分布式的、為Web Service提供的、信息注冊中心的實現標準規范,同時也包含一組使企業能將自身提供的Web Service注冊,以使別的企業能夠發現的訪問協議的實現標準。


          5、BS與CS的聯系與區別。
          希望大家補上,謝謝

          6、STRUTS的應用(如STRUTS架構)
          答:
          Struts是采用Java Servlet/JavaServer Pages技術,開發Web應用程序的開放源碼的framework。 采用Struts能開發出基于MVC(Model-View-Controller)設計模式的應用構架。 Struts有如下的主要功能:
          一.包含一個controller servlet,能將用戶的請求發送到相應的Action對象。
          二.JSP自由tag庫,并且在controller servlet中提供關聯支持,幫助開發員創建交互式表單應用。
          三.提供了一系列實用對象:XML處理、通過Java reflection APIs自動處理JavaBeans屬性、國際化的提示和消息。

          設計模式方面

          1、開發中都用到了那些設計模式?用在什么場合?
          答:
          每個模式都描述了一個在我們的環境中不斷出現的問題,然后描述了該問題的解決方案的核心。通過這種方式,你可以無數次地使用那些已有的解決方案,無需在重復相同的工作。主要用到了MVC的設計模式。用來開發JSP/Servlet或者J2EE的相關應用。簡單工廠模式等。


          2、UML方面
          答:
          標準建模語言UML。用例圖,靜態圖(包括類圖、對象圖和包圖),行為圖,交互圖(順序圖,合作圖),實現圖,

          JavaScript方面

          1、如何校驗數字型?
          var re=/^\d{1,8}$|\.\d{1,2}$/;
          var str=document.form1.all(i).value;
          var r=str.match(re);
          if (r==null)
          {
          ?? sign=-4;
          ?? break;
          }
          else{
          ?? document.form1.all(i).value=parseFloat(str);
          }


          CORBA方面

          1、CORBA是什么?用途是什么?
          答:
          CORBA 標準是公共對象請求代理結構(Common Object Request Broker Architecture),由對象管理組織 (Object Management Group,縮寫為 OMG)標準化。它的組成是接口定義語言(IDL), 語言綁定(binding:也譯為聯編)和允許應用程序間互操作的協議。 其目的為:
          用不同的程序設計語言書寫
          在不同的進程中運行
          為不同的操作系統開發


          LINUX方面

          1、LINUX下線程,GDI類的解釋。
          答:
          LINUX實現的就是基于核心輕量級進程的"一對一"線程模型,一個線程實體對應一個核心輕量級進程,而線程之間的管理在核外函數庫中實現。
          GDI類為圖像設備編程接口類庫。

          posted @ 2005-03-19 21:18 小毅 閱讀(274) | 評論 (0)編輯 收藏
          僅列出標題
          共7頁: 上一頁 1 2 3 4 5 6 7 下一頁 

          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章檔案

          blog 好友

          友情鏈接

          常用網站

          技術網站論壇

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 平定县| 页游| 太谷县| 大渡口区| 临武县| 神池县| 鹤庆县| 九台市| 漳平市| 名山县| 台南市| 辛集市| 云梦县| 建平县| 修水县| 义乌市| 长乐市| 朝阳区| 和硕县| 石阡县| 鱼台县| 辉南县| 察雅县| 乐陵市| 伊宁市| 获嘉县| 永年县| 沅陵县| 固始县| 深泽县| 大悟县| 滦平县| 周宁县| 镇远县| 武强县| 阜新市| 石狮市| 冷水江市| 华阴市| 楚雄市| 固原市|