C++或Java中的異常處理機(jī)制的簡(jiǎn)單原理和應(yīng)用_第1頁(yè)
C++或Java中的異常處理機(jī)制的簡(jiǎn)單原理和應(yīng)用_第2頁(yè)
C++或Java中的異常處理機(jī)制的簡(jiǎn)單原理和應(yīng)用_第3頁(yè)
C++或Java中的異常處理機(jī)制的簡(jiǎn)單原理和應(yīng)用_第4頁(yè)
C++或Java中的異常處理機(jī)制的簡(jiǎn)單原理和應(yīng)用_第5頁(yè)
已閱讀5頁(yè),還剩174頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1.C++或Java中的異常處理機(jī)制的簡(jiǎn)單原理和應(yīng)用。

當(dāng)JAVA程序違反了JAVA的語(yǔ)義規(guī)則時(shí),JAVA虛擬機(jī)就會(huì)將發(fā)生的錯(cuò)誤表示為一個(gè)異常。

違反語(yǔ)義規(guī)則包括2種情況。一種是JAVA類庫(kù)內(nèi)置的語(yǔ)義檢查。例如數(shù)組下標(biāo)越界,會(huì)引發(fā)In

dexOutOfBoundsException;訪問null的對(duì)象時(shí)會(huì)引發(fā)NuUPointerException?另一種情況就是

JAVA允許程序員擴(kuò)展這種語(yǔ)義檢查,程序員可以創(chuàng)建白己的異常,并自由選擇在何時(shí)用thro

w關(guān)鍵字引發(fā)異常。所有的異常都是java.lang.Thowable的子類。

2.Java的接口和C++的虛類的相同和不同處。

由于Java不支持多繼承,而有可能某個(gè)類或?qū)ο笠褂梅謩e在幾個(gè)類或?qū)ο罄锩娴姆椒ɑ驅(qū)傩?

現(xiàn)有的單繼承機(jī)制就不能滿足要求。與繼承相比,接口有更高的靈活性,因?yàn)榻涌谥袥]有任何

實(shí)現(xiàn)代碼。當(dāng)一個(gè)類實(shí)現(xiàn)了接口以后,該類要實(shí)現(xiàn)接口里面所有的方法和屬性,并且接口里面

的屬性在默認(rèn)狀態(tài)下面都是publicstatic,所有方法默認(rèn)情況下是public.一個(gè)類可以實(shí)現(xiàn)多個(gè)接

口。

3.垃圾回收的優(yōu)點(diǎn)和原理。并考慮2種回收機(jī)制。

Java語(yǔ)言中?個(gè)顯著的特點(diǎn)就是引入了垃圾回收機(jī)制,使C++程序員最頭疼的內(nèi)存管理的問題

迎刃而解,它使得Java程序員在編寫程序的時(shí)候不再需要考慮內(nèi)存管理。由于有個(gè)垃圾回收機(jī)

制,Java中的對(duì)象不再有“作用域”的概念,只有對(duì)象的引用才有“作用域”。垃圾回收可以有效

的防止內(nèi)存泄露,有效的使用可以使用的內(nèi)存。垃圾回收器通常是作為一個(gè)單獨(dú)的低級(jí)別的線

程運(yùn)行,不可預(yù)知的情況下對(duì)內(nèi)存堆中已經(jīng)死亡的或者長(zhǎng)時(shí)間沒有使用的對(duì)象進(jìn)行清楚和回收,

程序員不能實(shí)時(shí)的調(diào)用垃圾回收器對(duì)某個(gè)對(duì)象或所有對(duì)象進(jìn)行垃圾回收?;厥諜C(jī)制有分代復(fù)制

垃圾回收和標(biāo)記垃圾回收,增量垃圾回收。

4.請(qǐng)說(shuō)出你所知道的線程同步的方法。

wait。:使一個(gè)線程處于等待狀態(tài),并且釋放所持有的對(duì)象的lock,

sleep。:使一個(gè)正在運(yùn)行的線程處于睡眠狀態(tài),是一個(gè)靜態(tài)方法,調(diào)用此方法要捕捉Interrupte

dException異常。

notify。:喚醒一個(gè)處于等待狀態(tài)的線程,注意的是在調(diào)用此方法的時(shí)候,并不能確切的喚醒某

一個(gè)等待狀態(tài)的線程,而是由JVM確定喚醒哪個(gè)線程,而且不是按優(yōu)先級(jí)。

Allnotity():喚醒所有處入等待狀態(tài)的線程,注意并不是給所有喚醒線程一個(gè)對(duì)象的鎖,而是讓

它們競(jìng)爭(zhēng)。

5.請(qǐng)講一講析構(gòu)函數(shù)和虛函數(shù)的用法和作用。

6.Error與Exception有什么區(qū)別?

Error表示系統(tǒng)級(jí)的錯(cuò)誤和程序不必處理的異常,

Exception表示需要捕捉或者需要程序進(jìn)行處理的異常。

7.在java中一個(gè)類被聲明為final類型,表示了什么意思?

表示該類不能被繼承,是頂級(jí)類。

8.描述一下你最常用的編程風(fēng)格。

9.heap和stack有什么區(qū)另U。

棧是…種線形集合,其添加和刪除元素的操作應(yīng)在同一段完成。棧按照后進(jìn)先出的方式進(jìn)行處

理。

堆是棧的一個(gè)組成元素

10.如果系統(tǒng)要使用超大整數(shù)(超過(guò)k>ng氏度范圍),請(qǐng)你設(shè)計(jì)一個(gè)數(shù)據(jù)結(jié)構(gòu)來(lái)存儲(chǔ)這種超大

型數(shù)字以及設(shè)計(jì)一種算法來(lái)實(shí)現(xiàn)超大整數(shù)加法運(yùn)算)。

publicclassBiglnt()

int[]AirOne=newArr0ne[1000];

StringintString="";

publicinti]Arr(Strings)

intString=s;

fbr(inti=0;i<ArrOne.leght;i++)

11.如果要設(shè)tl?個(gè)圖形系統(tǒng),請(qǐng)你設(shè)計(jì)基本的圖形元件(Point.Line,Rectangle,Triangle)的簡(jiǎn)單

實(shí)現(xiàn)

12,談?wù)刦inal,finally,finalize的區(qū)別。

final—修飾符(關(guān)鍵字)如果個(gè)類被聲明為final,意味著它不能再派生出新的子類,不

能作為父類被繼承。因此一個(gè)類不能既被聲明為abstract的,又被聲明為final的。將變量或方

法聲明為final,可以保證它們?cè)谑褂弥胁槐桓淖?。被聲明為final的變量必須在聲明時(shí)給定初

值,而在以后的引用中只能讀取,不可修改。被聲明為final的方法也同樣只能使用,不能重載。

finally—S異常處理時(shí)提供finally塊來(lái)執(zhí)行任何清除操作。如果拋出一個(gè)異常,那么相匹

配的catch子句就會(huì)執(zhí)行,然后控制就會(huì)進(jìn)入finally塊(如果有的話)。

finalize—方法名。Java技術(shù)允許使用finalize。方法在垃圾收集器將對(duì)象從內(nèi)存中清除出

去之前做必要的清理工作。這個(gè)方法是由垃圾收集器在確定這個(gè)對(duì)象沒有被引用時(shí)對(duì)這個(gè)對(duì)象

調(diào)用的。它是在Object類中定義的,因此所有的類都繼承了它。子類覆蓋finalize。方法以整

理系統(tǒng)資源或者執(zhí)行其他清理工作。finalize。方法是在垃圾收集器刪除對(duì)象之前對(duì)這個(gè)對(duì)象調(diào)

用的。

13,AnonymousInnerClass(匿名內(nèi)部類)是否可以extends(繼承)其它類,是否可以impleme

nts(實(shí)現(xiàn))interface(接口)?

匿名的內(nèi)部類是沒有名字的內(nèi)部類。不能extends(繼承)其它類,但一個(gè)內(nèi)部類可以作為

一個(gè)接口,由另一個(gè)內(nèi)部類實(shí)現(xiàn)。

14,StaticNestedClass和InnerClass的不同,說(shuō)得越多越好(面試題有的很籠統(tǒng))。

NestedClass(一般是C++的說(shuō)法),InnerClass(一般是JAVA的說(shuō)法)。Java內(nèi)部類與

C++嵌套類最大的不同就在于是否有指向外部的引用上。具體可見http:///

articles/services/view.asp?id=704&page=1

注:靜態(tài)內(nèi)部類(InnerClass)意味著1創(chuàng)建-一個(gè)static內(nèi)部類的對(duì)象,不需要一個(gè)外部

類對(duì)象,2不能從一個(gè)static內(nèi)部類的一個(gè)對(duì)象訪問…個(gè)外部類對(duì)象

第四,&和&&的區(qū)別。

&是位運(yùn)算符。&&是布爾邏輯運(yùn)算符。

15,HashMap和Hashtable的區(qū)別。

都屬于Map接口的類,實(shí)現(xiàn)了將惟一鍵映射到特定的值上。

HashMap類沒有分類或者排序。它允許一個(gè)null鍵和多個(gè)null值。

Hashtable類似于HashMap,但是不允許null鍵和null值。它也比HashMap慢,因?yàn)?/p>

它是同步的。

16.Collection和Collections的區(qū)別。

Collections是個(gè)java.util下的類,它包含有各種有關(guān)集合操作的靜態(tài)方法。

Collection是個(gè)java.util下的接IJ,它是各種集合結(jié)構(gòu)的父接口。

17,什么時(shí)候用asserto

斷言是一個(gè)包含布爾表達(dá)式的語(yǔ)句,在執(zhí)行這個(gè)語(yǔ)句時(shí)假定該表達(dá)式為true。如果表達(dá)式

計(jì)算為false,那么系統(tǒng)會(huì)報(bào)告一個(gè)Asserlioneiror。它用于調(diào)試目的:

assert(a>0);//throwsanAssertionerrorifa<=0

斷言可以有兩種形式:

assertExpression1;

assertExpression1:Expression?;

Expression1應(yīng)該總是產(chǎn)生一個(gè)布爾值。

Expression2可以是得出一個(gè)值的任意表達(dá)式。這個(gè)值用于生成顯示更多調(diào)試信息的Strin

g消息。

斷言在默認(rèn)情況下是禁用的。要在編譯時(shí)啟用斷言,需要使用source1.4標(biāo)記:

javac-source1.4Test.java

要在運(yùn)行時(shí)啟用斷言,可使用-enableassertions或者-ea標(biāo)記。

要在運(yùn)行時(shí)選擇禁用斷言,可使用-da或者-disableassertions標(biāo)記。

要系統(tǒng)類中啟用斷言,可使用-esa或者-dsa標(biāo)記。還M以在包的基礎(chǔ)上啟用或者禁用斷

言。

可以在預(yù)計(jì)正常情況下不會(huì)到達(dá)的任何位置上放置斷言。斷言可以用于驗(yàn)證傳遞給私有方

法的參數(shù)。不過(guò),斷言不應(yīng)該用于驗(yàn)證傳遞給公有方法的參數(shù),因?yàn)椴还苁欠駟⒂昧藬嘌?,?/p>

有方法都必須檢查其參數(shù)。不過(guò),既可以在公有方法中,也可以在非公有方法中利用斷言測(cè)試

后置條件。另外,斷言不應(yīng)該以任何方式改變程序的狀態(tài)。

18.GC是什么?為什么要有GC?(基礎(chǔ))。

GC是垃圾收集器。Java程序員不用擔(dān)心內(nèi)存管理,因?yàn)槔占鲿?huì)自動(dòng)進(jìn)行管理。要

請(qǐng)求垃圾收集,可以調(diào)用下面的方法之一:

System.gc()

Runtime.getRuntime().gc()

19,Strings=newString("xyz");創(chuàng)建了幾個(gè)StringObject?

兩個(gè)對(duì)象,一個(gè)是“xyx”,一個(gè)是指向Xyx”的引用對(duì)象s。

20,Math.round(11.5)等於多少?Math.round(-11.5)等於多少?

Math.round(11.5)返回(long)12,Math.round(?lL5)返回(long)-11;

21,shortsi=1;si=si+1;有什么錯(cuò)?shortsi=1;si+=1;有什么錯(cuò)?

shortsi=I;si=si+1;有錯(cuò),si是short型,sl+1是int型,不能顯式轉(zhuǎn)化為short型???/p>

修改為si=(short)(sl+I)oshortsi=1;si+=1正確。

22,sleepQ和wait()有什么區(qū)別?搞線程的最愛

sleep。方法是使線程停止一段時(shí)間的方法。在sleep時(shí)間間隔期滿后,線程不一定立即恢

復(fù)執(zhí)行。這是因?yàn)樵谀莻€(gè)時(shí)刻,其它線程可能正在運(yùn)行而且沒有被調(diào)度為放棄執(zhí)行,除非(a)

“醒來(lái)”的線程具有更高的優(yōu)先級(jí)(b)正在運(yùn)行的線程因?yàn)槠渌蚨枞?/p>

wait。是線程交互時(shí),如果線程對(duì)一個(gè)同步對(duì)象x發(fā)出一個(gè)wait。調(diào)用,該線程會(huì)暫停執(zhí)行,

被調(diào)對(duì)象進(jìn)入等待狀態(tài),直到被喚醒或等待時(shí)間到。

23,Java有沒有g(shù)oto?

GotoTava中的保留字,現(xiàn)在沒有在java中使用。

24,數(shù)組有沒有l(wèi)ength。這個(gè)方法?String有沒有l(wèi)ength。這個(gè)方法?

數(shù)組沒有l(wèi)ength。這個(gè)方法,有l(wèi)ength的屬性。

String有有l(wèi)ength。這個(gè)方法。

251Overload和Override的區(qū)別。Overloaded的方法是否可以改變返回值的類型?

方法的重寫Overriding和重載Overloading是Java多態(tài)性的不同表現(xiàn)。重寫Overriding

是父類與子類之間多態(tài)性的一種表現(xiàn),重載Overloading是一個(gè)類中多態(tài)性的一種表現(xiàn)。如果

在子類中定義某方法與其父類有相同的名稱和參數(shù),我們說(shuō)該方法被重寫(Overriding)。子類

的對(duì)象使用這個(gè)方法時(shí),將調(diào)用子類中的定義,對(duì)它而言,父類中的定義如同被“屏蔽”了。如

果在一個(gè)類中定義了多個(gè)同名的方法,它們或有不同的參數(shù)個(gè)數(shù)或有不同的參數(shù)類型,則稱為

方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。

26,Set里的元素是不能重復(fù)的,那么用什么方法來(lái)區(qū)分重復(fù)與否呢?是用==還是equals。?它

們有何區(qū)別?

Set里的元素是不能重復(fù)的,那么用iterator。方法來(lái)區(qū)分重復(fù)與否。equals。是判讀兩個(gè)S

et是否相等。

64皿卜()和==方法決定引用值是否指向同一對(duì)象equals。在類中被覆蓋,為的是當(dāng)兩個(gè)分

離的對(duì)象的內(nèi)容和類型相配的話,返回真值。

27,給我一個(gè)你最常見到的runtimeexception。

ArithmeticException,ArrayStoreException.BufferOverflowException,BufferUnderflowExcep

tion,CannotRedoException,CannotUndoException,ClassCastException,CMMException,Co

ncurrentModificationException,DOMException,EmptyStackException,IllegalAigumentExce

ption,IllegalMonitorStateException,IllegalPathStateException,IllegalStateException,

ImagingOpException,IndexOutOfBoundsException,MissingResourceException,NegativeArr

aySizeException,NoSuchElementException,NuUPointerException,ProfileDataException,Pr

oviderException,RasterFORMatException,SecurityException,SystemException,Undeclared

ThrowableException,UnmodifiableSetException,UnsupportedOperationException

28,error和exception有什么區(qū)別?

error表示恢復(fù)不是不可能但很困難的情況下的一種嚴(yán)重問題。比如說(shuō)內(nèi)存溢出。不可能指

望程序能處理這樣的情況。

exception表示一種設(shè)計(jì)或?qū)崿F(xiàn)問題。也就是說(shuō),它表示如果程序運(yùn)行正常,從不會(huì)發(fā)生的

情況。

29,List,Set,Map是否繼承自Collection接口?

List.Set是

Map不是

30,abstractclass和interface有什么區(qū)別?

聲明方法的存在而不去實(shí)現(xiàn)它的類被叫做抽象類(abstractclass),它用于要?jiǎng)?chuàng)建一個(gè)體

現(xiàn)某些基本行為的類,并為該類聲明方法,但不能在該類中實(shí)現(xiàn)該類的情況。不能創(chuàng)建abstrac

t類的實(shí)例。然而可以創(chuàng)建一個(gè)變量,其類型是一個(gè)抽象類,并讓它指向具體子類的一個(gè)實(shí)例。

不能有抽象構(gòu)造函數(shù)或抽象靜態(tài)方法。Abstract類的子類為它們父類中的所有抽象方法提供實(shí)

現(xiàn),否則它們也是抽象類為。取而代之,在子類中實(shí)現(xiàn)該方法。知道其行為的其它類可以在類

中實(shí)現(xiàn)這些方法。

接口(interface)是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過(guò)實(shí)

現(xiàn)這樣的接口而獲得。接口中的所有方法都是抽象的,沒有一個(gè)有程序體。接口只可以定義st

aticfinal成員變量。接口的實(shí)現(xiàn)與子類相似,除了該實(shí)現(xiàn)類不能從接口定義中繼承行為。當(dāng)類

實(shí)現(xiàn)特殊接口時(shí),它定義(即將程序體給予)所有這種接口的方法。然后,它可以在實(shí)現(xiàn)了該

接口的類的任何對(duì)象上調(diào)用接口的方法。由于有抽象類,它允許使用接口名作為引用變量的類

型。通常的動(dòng)態(tài)聯(lián)編將生效。引用可以轉(zhuǎn)換到接口類型或從接口類型轉(zhuǎn)換,instanceof運(yùn)算符

可以用來(lái)決定某對(duì)象的類是否實(shí)現(xiàn)了接口。

31,abstract的method是否可同時(shí)是static,是杳可同時(shí)是native,是否可同時(shí)是synchronize

d?

都不能

32,接口是否可繼承接口?抽象類是否可實(shí)現(xiàn)(implements)接口?抽象類是否可繼承實(shí)體類(con

creteclass)?

接口可以繼承接口。抽象類可以實(shí)現(xiàn)(implements)接口,抽象類是否可繼承實(shí)體類,但前

提是實(shí)體類必須有明確的構(gòu)造函數(shù)。

33,啟動(dòng)一個(gè)線程是用run()還是start()?

啟動(dòng)一個(gè)線程是調(diào)用start。方法,使線程所代表的虛擬處理機(jī)處于可運(yùn)行狀態(tài),這意味著

它可以由JVM調(diào)度并執(zhí)行。這并不意味著線程就會(huì)立即運(yùn)行。run。方法可以產(chǎn)生必須退出的

標(biāo)志來(lái)停止一個(gè)線程。

34,構(gòu)造器Constructor是否可被override?

構(gòu)造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloading。

35,是否可以繼承String類?

Siring類是Anal類故不可以繼承。

36,當(dāng)一個(gè)線程進(jìn)入一個(gè)對(duì)象的一個(gè)synchronized方法后,其它線程是否可進(jìn)入此對(duì)象的其它

方法?

不能,一個(gè)對(duì)象的一個(gè)synchronized方法只能由一個(gè)線程訪問。

37,try{}里有一個(gè)return語(yǔ)句,那么緊跟在這個(gè)try后的finally{}里的code會(huì)不會(huì)被執(zhí)行,

什么時(shí)候被執(zhí)行,在return前還是后?

會(huì)執(zhí)行,在return前執(zhí)行。

38,編程題:用最有效率的方法算出2乘以8等於幾?

有C背景的程序員特別喜歡問這種問題。

2?3

39,兩個(gè)對(duì)象值相同(x.equals(y)==true),但卻可有不同的hashcode,這句話對(duì)不對(duì)?

不對(duì),有相同的hashcodec

40,當(dāng)一個(gè)對(duì)象被當(dāng)作參數(shù)傳遞到一個(gè)方法后,此方法可改變這個(gè)對(duì)象的屬性,并可返回變化

后的結(jié)果,那么這里到底是值傳遞還是引用傳遞?

是值傳遞。Java編程語(yǔ)言只由值傳遞參數(shù)。當(dāng)一個(gè)對(duì)象實(shí)例作為一個(gè)參數(shù)被傳遞到方法中

時(shí),參數(shù)的值就是對(duì)該對(duì)象的引用。對(duì)象的內(nèi)容可以在被調(diào)用的方法中改變,但對(duì)象的引用是

永遠(yuǎn)不會(huì)改變的。

41,swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?

switch(exprl)中,expr1是一個(gè)整數(shù)表達(dá)式。因此傳遞給switch和case語(yǔ)句的參數(shù)應(yīng)

該是int、shortNchar或者byte。long,string都不能作用丁?swtich0

42,編程題:寫一個(gè)Singleton出來(lái)。

Singleton模式主要作用是保證在Java應(yīng)用程序中,一個(gè)類Class只有一個(gè)實(shí)例存在。

一般Singleton模式通常有幾種種形式:

第一種形式:定義i個(gè)類,它的構(gòu)造函數(shù)為private的,它有一個(gè)static的private的該類

變量,在類初始化時(shí)實(shí)例話,通過(guò)一個(gè)public的getlnstance方法獲取對(duì)它的引用,繼而調(diào)用其

中的方法。

publicclassSingleton{

privateSingleton(){}

〃在自己內(nèi)部定義自己一個(gè)實(shí)例,是不是很奇怪?

〃注意這是private只供內(nèi)部調(diào)用

privatestaticSingletoninstance=newSingleton();

〃這里提供了?個(gè)供外部訪問本class的靜態(tài)方法,可以直接訪問

publicstaticSingletongetlnstance(){

returninstance;

)

第二種形式:

publicclassSingleton{

privatestaticSingletoninstance=null;

publicstaticsynchronizedSingletongetlnstance(){

〃這個(gè)方法比上面有所改進(jìn),不用每次都進(jìn)行生成對(duì)象,只是第一次

〃使用時(shí)生成實(shí)例,提高了效率!

if(instance==null)

instance=newSingleton();

returninstance;

其他形式:

定義一個(gè)類,它的構(gòu)造函數(shù)為private的,所有方法為static的。

一般認(rèn)為第一種形式要更加安全些

Hashtable和HashMap

Hashtable繼承自Dictionary類,而HashMap是Javal.2引進(jìn)的Mapinterface的一個(gè)實(shí)

現(xiàn)

HashMap允許將null作為一個(gè)entry的key或者value,而Hashtable不允許

還有就是,HashMap把Hashtable的contains方法去掉了,改成containsvalue和contai

nsKey,因?yàn)閏ontains方法容易讓人引起誤解。

最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在

多個(gè)線程訪問Hashtable時(shí),不需要自己為它的方法實(shí)現(xiàn)同步,而HashMap

就必須為之提供外同步。

Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會(huì)有很大的差異。

43.描述一下JVM加載class文件的原理機(jī)制?

44.試舉例說(shuō)明個(gè)典型的垃圾回收算法?

45.請(qǐng)用java寫二*樹算法,實(shí)現(xiàn)添加數(shù)據(jù)形成二*樹功能,并以先序的方式打印出來(lái).

46.請(qǐng)寫一個(gè)java程序?qū)崿F(xiàn)線程連接池功能?

47.給定一個(gè)C語(yǔ)言函數(shù),要求實(shí)現(xiàn)在java類中進(jìn)行調(diào)用。

48、編一段代碼,實(shí)現(xiàn)在控制臺(tái)輸入一組數(shù)字后,排序后在控制臺(tái)輸出:

49、列出某文件夾下的所有文件;

50、調(diào)用系統(tǒng)命令實(shí)現(xiàn)刪除文件的操作:

51、實(shí)現(xiàn)從文件中一次讀出一個(gè)字符的操作;

52、列出一些控制流程的方法;

53、多線程有哪些狀態(tài)?

54、編寫了?個(gè)服務(wù)器端的程序?qū)崿F(xiàn)在客戶端輸入字符然后在控制臺(tái)上顯示,直到輸入“END”

為止,讓你寫出客戶端的程序;

55>作用域public,private,protected,以及不寫時(shí)的區(qū)別

答:區(qū)別如下:

作用域當(dāng)前類同一package廣孫類其他package

public7777

protected777*

friendlyVVxx

privateVxxx

不寫時(shí)默認(rèn)為friendly

56、ArrayList和Vector的區(qū)別,HashMap和Hashtable的區(qū)別

答:就ArrayList與Vector主要從二方面來(lái)說(shuō).

一.同步性:Vector是線程安全的,也就是說(shuō)是同步的,而ArrayList是線程序不安全的,不是同

步的

二.數(shù)據(jù)增長(zhǎng):當(dāng)需要增長(zhǎng)時(shí),Vector默認(rèn)增長(zhǎng)為原來(lái)一培,而ArrayList卻是原來(lái)的一半

就HashMap與HashTable主要從三方面來(lái)說(shuō)。

一.歷史原因:Hashtable是基于陳舊的Dictionary類的,HashMap是Java1.2引進(jìn)的Map接口

的一個(gè)實(shí)現(xiàn)

二.同步性:Hashtable是線程安全的,也就是說(shuō)是同步的,而HashMap是線程序不安全的,不

是同步的

三.值:只有HashMap可以讓你將空值作為--個(gè)表的條目的key或value

57、char型變量中能不能存貯一個(gè)中文漢字?為什么?

答:是能夠定義成為一個(gè)中文的,因?yàn)閖ava中以u(píng)nicode編碼,一個(gè)char占16個(gè)字節(jié),所以

放一個(gè)中文是沒問題的

58、多線程有幾種實(shí)現(xiàn)方法,都是什么?同步有幾種實(shí)現(xiàn)方法,都是什么?

答:多線程有兩種實(shí)現(xiàn)方法,分別是繼承Thread類與實(shí)現(xiàn)Runnable接口

同步的實(shí)現(xiàn)方面有兩種,分別是synchronized.wait與notify

59、垃圾回收機(jī)制,如何優(yōu)化程序?

希望大家補(bǔ)上,謝謝

60、float型floatf=3.4是否正確?

答:不正確。精度不準(zhǔn)確,應(yīng)該用強(qiáng)制類型轉(zhuǎn)換,如卜所示:floatf=(float)3.4

61、介紹JAVA中的CollectionFrameWork(包括如何寫自己的數(shù)據(jù)結(jié)構(gòu))?

答:CollectionFrameWork如下:

Collection

卜List

I|-LinkeclList

|卜ArrayList

ILVector

LStack

LSet

Map

卜Hashtable

|-HashMap

LWeakHashMap

Collection是最基本的集合接口,--個(gè)Collection代表一組Object,即Collection的元素(Ele

ments)

Map提供key到value的映射

62、Java中異常處理機(jī)制,事件機(jī)制?

11、JAVA中的多形與繼承?

希望大家補(bǔ)匕謝謝

63、抽象類與接口?

答:抽象類與接口都用于抽象,但是抽象類(JAVA中)可以有自己的部分實(shí)現(xiàn),而接口則完全是

一個(gè)標(biāo)識(shí)(同時(shí)有多重繼承的功能)。

編程題:

1.現(xiàn)在輸入n個(gè)數(shù)字,以逗號(hào),分開;

然后可選擇升或者降序排序;

按提交鍵就在另一頁(yè)面顯示

按什么排序,結(jié)果為,

提供reset

答案(1)publicstaticString[jsplitStringByComma(Stringsource){

if(source==nulllIsource.trim。.equals。"))

returnnull;

StringTokenizercommaToker=newStringTokenizer(source,"/')?

String[Jresult=newString[commaToker.countTokens()];

inti=();

while(commaToker.hasMoreTokens()){

result[i]=commaToker.nextToken();

i++;

returnresult;

循環(huán)遍歷String數(shù)組

Integer.parseInt(Slrings)變成int類型

組成int數(shù)組

Arrays.sort(intf]a),

a數(shù)組升序

降序可以從尾部開始輸出

2.金額轉(zhuǎn)換,阿拉伯?dāng)?shù)字的金額轉(zhuǎn)換成中國(guó)傳統(tǒng)的形式如:

(¥1011)->(一千零一拾?元整)輸出。

3、繼承時(shí)候類的執(zhí)行順序問題,一般都是選擇題,問你將會(huì)打印出什么?

答:父類:

packagetest;

publicclassFatherClass

publicFatherClass()

System.out.printIn("FatherClassCreate");

子類:

packagetest;

importtest.FatherClass;

publicclassChildClassextendsFatherClass

publicChildClass()

System.out.printIn("ChildClassCreate");

publicstaticvoidniain(String[]args)

FatherClassfc=newFatherClass();

ChildClasscc=newChildClass();

輸出結(jié)果:

C:>javatest.ChildClass

FatherCIassCreate

FatherClassCreate

ChildClassCreate

4、內(nèi)部類的實(shí)現(xiàn)方式?

答:示例代碼如下:

packagetest;

publicclassOuterClass

privateclassInterClass

publiclnterClass()

System.out.println("InterClassCreate");

publicOuterClassO

InterClassic=newlnterClass();

System.out.printIn(MOuterClassCreate1');

publicstaticvoidmain(String[]args)

OuterClassoc=newOuterClass();

輸出結(jié)果:

C:>javatest/OuterClass

InterClassCreate

OuterClassCreate

再一個(gè)例題:

publicclassOuterClass{

privatedoubled1=1.0;

//insertcodehere

Youneedtoinsertaninnerclassdeclarationatline3.Whichtwoinnerclassdeclarationsare

valid?(Choosetwo.)

A.classInnerOne{

publicstaticdoublemethoda(){returnd1;}

B.publicclassInnerOne{

staticdoublemethoda(){returnd1;}

C.privateclassInnerOne{

doublemethoda(){returnd1;}

D.staticclassInnerOne{

protecteddoublemethoda(){returndl;}

)

E.abstractclassInnerOne{

publicabstractdoublemethoda();

說(shuō)明如下:

一.靜態(tài)內(nèi)部類可以有靜態(tài)成員,而非靜態(tài)內(nèi)部類則不能有靜態(tài)成員。故A、B錯(cuò)

二.靜態(tài)內(nèi)部類的非靜態(tài)成員可以訪問外部類的靜態(tài)變量,而不可訪問外部類的非靜態(tài)變量;ret

urnd1出錯(cuò)。

故D錯(cuò)

三.非靜態(tài)內(nèi)部類的非靜態(tài)成員可以訪問外部類的非靜態(tài)變量。故C正確

四.答案為C、E

5、Java的通信編程,編程題(或問答),用JAVASOCKET編程,讀服務(wù)器幾個(gè)字符,再寫入

本地顯示?

答:Server端程序:

packagetest;

import.*;

importjava.io.*;

publicclassServer

privateServerSocketss;

privateSocketsocket;

privateBufferedReaderin;

privatePrintWriterout;

publicServer()

ss=newServerSocket(10000);

while(true)

socket=ss.accept();

StringRemotelP=socket.getInetAddress().getHostAddress();

StringRemotePort=H:H+socket.getLocalPort();

System.out.println("Aclientcomein!lP:"+RemoteIP+RemotePort);

in=newBufferedReader(new

InputStreaniReader(socket.getInputStream()));

Stringline=in.readLine();

System.out.println(HCleintsendis:"+line);

out=newPrintWriter(socket.getOutputStream(),true);

out.println("YourMessageReceived!*');

out.close();

in.close();

socket.close();

}catch(lOExceptione)

out.println(Mwrongn);

publicstaticvoidmain(String[]args)

newServer();

);

Client端程序:

packagetest;

importjava.io.*;

import.*;

publicclassClient

Socketsocket;

BufferedReaderin;

PrintWriterout;

publicClient()

try

System.out.println("TrytoConnectto:100000);

socket=newSocket(Hu,10000);

System.out.println(HTheServerConnected!'*);

System.out.printin("PleaseentersomeCharacter:");

BufferedReaderline=newBufferedReader(new

InputStreamReader(System.in));

out=newPrintWriter(socket.getOutputStream(),true);

out.printin(line.readLine());

in=newBufferedReader(newInputStreamReader(socket.getInputStream()));

System.out.println(in.readLine());

out.close();

in.close();

socket.close();

}catch(IOExceptione)

out.printIn("Wrong");

publicstaticvoidmain(String[]args)

newClient();

};

6、用JAVA實(shí)現(xiàn)一種排序,JAVA類實(shí)現(xiàn)序列化的方法(二種)?如在COLLECTION框架中,

實(shí)現(xiàn)比較要實(shí)現(xiàn)什么樣的接口?

答:用插入法進(jìn)行排序代碼如下

packagetest;

importjava.util.*;

classInsertSort

ArrayListal;

publicInsertSort(intnum,intmod)

al=newArrayList(num);

Randomrand=newRandom();

System.out.println(MTheArrayListSortBefore:");

for(inti=0;i<num;i++)

aLadd(newInteger(Math.abs(rand.nextInt())%mod+1));

System.out.println(Mal[,,+i+',]="4-al.get(i));

publicvoidSortlt()

Integertemplnt;

intMaxSize=l;

for(inti=l;i<al.size();i++)

templnt=(Integer)al.reinove(i);

if(tempIValue()>=((Integer)al.get(MaxSize-l)).intValue())

al.add(MaxSize,tempInt);

MaxSize++;

System.out.println(al.toStringO);

}else{

for(intj=O;j<MaxSize;j++)

if

(((Integer)al.get(j)).intValue()>=tempIValue())

al.add(j,teniplnt);

MaxSize++;

System.out.printIn(al.toStringO);

break;

System.out.println(HTheArrayListSortAfter:");

fbr(inti=O;i<al.size();i++)

System.out.println(Mal[M+i+"]=*,+al.get(i));

publicstaticvoidmain(String[]args)

InsertSortis=newlnsertSort(10,100);

is.SortIt();

JAVA類實(shí)現(xiàn)序例化的方法是實(shí)現(xiàn)java.io.Serializable接II

Collection框架中實(shí)現(xiàn)比較要實(shí)現(xiàn)Comparable接口和Comparator接口

7、編程:編寫一個(gè)截取字符串的函數(shù),輸入為一個(gè)字符串和字節(jié)數(shù),輸出為按字節(jié)截取的字符

串。但是要保證漢字不被截半個(gè),如“我ABC”4,應(yīng)該截為“我AB”,輸入“我ABC漢DEF",6,

應(yīng)該輸出為“我ABC”而不是“我ABC+漢的半個(gè)”。

答:代碼如下:

packagetest;

classSplitString

StringSplitStr;

intSplitByte;

publicSplitString(Stringstr,intbytes)

SplitStr=str;

SplitByte=bytes;

System.out.println("TheStringis:+SplitStrH-1'f;SplitBytes="+SplitByte);

publicvoidSplitlt()

intloopCount;

loopCount=(SplitStr.length(}%SplitByte==O)?(SplitStr.length()/SplitByte):(SplitStr.length()/

Split

Byte+1);

System.out.println(HWillSplitinto"+loopCount);

for(inti=l;i<=loopCount;i++)

if(i==loopCount){

System.out.println(Sp!itStr.substring((i-l)*SplitByte,SplitStr.length()));

}else{

System.out.println(SplitStr.substring((i-l)*SplitByte,(i*SplitByte)));

publicstaticvoidmain(String[]args)

SplitStringss=newSplitString(utest中dd文dsaf中男大3443n中國(guó)43中國(guó)人

0ewldfls=103n,4);

ss.SplitIt();

8、JAVA多線程編程。用JAVA寫一個(gè)多線程程序,如寫四個(gè)線程,二個(gè)加1,二個(gè)對(duì)一個(gè)變

量減一,輸出。

希望大家補(bǔ)上,謝謝

9、STRING與STRINGBUFFER的區(qū)別。

答:STRING的長(zhǎng)度是不可變的,STRINGBUFFER的長(zhǎng)度是可變的。如果你對(duì)字符串中的內(nèi)

容經(jīng)常進(jìn)行操作,特別是內(nèi)容要修改時(shí),那么使用StringBuffer,如果最后需要String,那么

使用StringBuffer的toString()方法

Jsp方面

1、jsp有哪些內(nèi)置對(duì)象?作用分別是什么?

答:JSP共有以下9種基本內(nèi)置組件(可與ASP的6種內(nèi)部組件相對(duì)應(yīng)):

request用戶端請(qǐng)求,此請(qǐng)求會(huì)包含來(lái)自GET/POST請(qǐng)求的參數(shù)

response網(wǎng)頁(yè)傳回用戶端的回應(yīng)

pageContext網(wǎng)頁(yè)的屬性是在這里管理

session與請(qǐng)求有關(guān)的會(huì)話期

applicationservlet正在執(zhí)行的內(nèi)容

out用來(lái)傳送回應(yīng)的輸出

configservlet的構(gòu)架部件

pageJSP網(wǎng)頁(yè)本身

exception針對(duì)錯(cuò)誤網(wǎng)頁(yè),未捕捉的例外

2、jsp有哪些動(dòng)作?作用分別是什么?

答:JSP共有以下6種基本動(dòng)作

jsp:include:在頁(yè)面被請(qǐng)求的時(shí)候引入一個(gè)文件。

jsp:useBean:尋找或者實(shí)例化一個(gè)JavaBean。

jsp:setProperty:設(shè)置JavaBean的屬性。

jsp:getProperty:輸出某個(gè)JavaBean的屬性。

jsp:forward:把請(qǐng)求轉(zhuǎn)到一個(gè)新的頁(yè)面。

jsp:plugin:根據(jù)瀏覽器類型為Java插件生成OBJECT或EMBED標(biāo)記

3、JSP中動(dòng)態(tài)INCLUDE與靜態(tài)INCLUDE的區(qū)別?

答:動(dòng)態(tài)INCLUDE用jsp:include動(dòng)作實(shí)現(xiàn)

<jsp:includepage="included.jsp"flush="true"/>它總是會(huì)檢查所含文件中的變化,適合用于

包含動(dòng)態(tài)頁(yè)面,并且可以帶參數(shù)

靜態(tài)INCLUDE用include偽碼實(shí)現(xiàn),定不會(huì)檢查所含文件的變化,適用丁?包含靜態(tài)頁(yè)面

<%@includefile=uincluded.htm"%>

4、兩種跳轉(zhuǎn)方式分別是什么?有什么區(qū)別?

答:有兩種,分別為:

<jsp:includepage=uincluded.jspHflush=ntrue">

<jsp:forwardpage=Mnextpage.jsp'7>

前者頁(yè)面不會(huì)轉(zhuǎn)向include所指的頁(yè)面,只是顯示該頁(yè)的結(jié)果,主頁(yè)面還是原來(lái)的頁(yè)面。執(zhí)行

完后還會(huì)回來(lái),相當(dāng)于函數(shù)調(diào)用。并且可以帶參數(shù).后者完全轉(zhuǎn)向新頁(yè)面,不會(huì)再回來(lái)。相當(dāng)于

goto語(yǔ)句。

Servlet方面

1、說(shuō)一說(shuō)Servlet的生命周期?

答:servlet有良好的生存期的定義,包括加載和實(shí)例化、初始化、處理請(qǐng)求以及服務(wù)結(jié)束。這個(gè)

生存期由javax.servlet.Servlet接口的init,service和destroy方法表達(dá)。

2、Servlet版本間(忘了問的是哪兩個(gè)版本了)的不同?

希望大家補(bǔ)上,謝謝

3、JAVASERVLETAPI中forward()與redirect。的區(qū)別?

答:前者僅是容器中控制權(quán)的轉(zhuǎn)向,在客戶端瀏覽器地址欄中不會(huì)顯示出轉(zhuǎn)向后的地址;后者則

是完全的跳轉(zhuǎn),瀏覽器將會(huì)得到跳轉(zhuǎn)的地址,并重新發(fā)送請(qǐng)求鏈接。這樣,從瀏覽器的地址欄

中可以看到跳轉(zhuǎn)后的鏈接地址。所以,前者更加高效,在前者可以滿足需要時(shí),盡量使用forw

ard()方法,并且,這樣也有助于隱藏實(shí)際的鏈接。在有些情況下,比如,需要跳轉(zhuǎn)到一個(gè)其它

服務(wù)器1:的資源,則必須使用sendRedirect。方法。

4、Servlet的基本架構(gòu)

publicclassServletNameextendsHttpServlet(

publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throws

ServletException,lOException{

publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throws

ServletException,lOException{

Jdbc>Jdo方面

1、可能會(huì)讓你寫一段Jdbc連Oracle的程序,并實(shí)現(xiàn)數(shù)據(jù)查詢.

答:程序如下:

packagehello.ant;

importjava.sql.*;

publicclassjdbc

StringdbUrl="jdbc:oracle:thin:@:1521:orcln;

StringtheUser=Hadmin

StringthePw="manager";

Connectionc=null;

Statementconn;

ResuItSetrs=null;

publicjdbc()

try(

Class.forName(uoracle.jdbc.driver.OracleDriver").newlnstance();

c=DriverManager.getConnection(dbUrLtheUser,thePw);

conn=c.createStatement();

}catch(Exceptione){

e.printStackTrace();

publicbooleanexecuteUpdate(Stringsql)

conn.executeUpdate(sql);

returntrue;

catch(SQLExceptione)

e.printStackTrace();

returnfalse;

publicResultSetexecuteQuery(Stringsql)

rs=null;

try

rs=conn.executeQuery(sq1);

catch(SQLExceptione)

e.printStackTrace();

returnrs;

publicvoidclose()

conn.close();

c.close();

catch(Exceptione)

e.printStackTrace();

publicstaticvoidmain(String[]args)

ResultSetrs;

jdbcconn=newjdbc();

rs=conn.executeQuery("select*fromtest1');

try(

while(rs.next())

System.out.println(rs.getString(nid"));

System.out.println(rs.getString(uname"));

}catch(Exceptione)

e.printStackTrace();

2、Class.forName的作用?為什么要用?

答:調(diào)用該訪問返回一個(gè)以字符串指定類名的類的對(duì)象。

3、Jdo是什么?

答:JDO是Java對(duì)象持久化的新的規(guī)范,為javadataobject的簡(jiǎn)稱,也是一個(gè)用于存取某種數(shù)

據(jù)倉(cāng)庫(kù)中的對(duì)象的標(biāo)準(zhǔn)化API。JDO提供「透明的對(duì)象存儲(chǔ),因此對(duì)開發(fā)人員來(lái)說(shuō),存儲(chǔ)數(shù)據(jù)

對(duì)象完全不需要額外的代碼(如JDBCAPI的使用)。這些繁瑣的例行工作已經(jīng)轉(zhuǎn)移到JDO產(chǎn)

品提供商身上,使開發(fā)人員解脫出來(lái),從而集中時(shí)間和精力在業(yè)務(wù)邏輯上。另外,JDO很靈活,

因?yàn)樗梢栽谌魏螖?shù)據(jù)底層上運(yùn)行。JDBC只是面向關(guān)系數(shù)據(jù)庫(kù)(RDBMS)JDO更通用,提供

到任何數(shù)據(jù)底層的存儲(chǔ)功能,比如關(guān)系數(shù)據(jù)庫(kù)、文件、XML以及對(duì)象數(shù)據(jù)庫(kù)(ODBMS)等等,

使得應(yīng)用可移植性更強(qiáng)。

4、在ORACLE大數(shù)據(jù)量下的分頁(yè)解決方法。一般用截取ID方法,還有是三層嵌套方法。

答:一種分頁(yè)方法

<%

inti=I;

intnumPages=14;

Stringpages=request.getParameter("page");

intcurrentPage=1;

currentPage=(pages==null)?(l):{Integer.parselnt(pages))

sql="selectcount(*)fromtables',;

ResuItSetrs=DBLink.executeQuery(sql);

while(rs.next())i=rs.getlnt(1);

iniintPageCount=l;

intPageCount=(i%numPages==0)?(i/numPages):(i/numPages+1);

intnextPage;

intupPage;

nextPage=currentPage+1;

if(nextPage>=intPageCount)nextPage=intPageCount;

upPage=current1;

if(upPage<=l)upPage=l;

rs.close();

sql="select*fromtables11;

rs=DBLink.executeQuery(sql);

i=0;

while((i<numPages*(currentl))&&rs.next()){i+4-;}

%>

〃輸出內(nèi)容

〃輸出翻頁(yè)連接

In*rh<%=currentPage%>/<%=intPageCount%xahref="List.jsp?page=l">第一頁(yè)</a><a

href=MList.jsp?page=<%=upPage%>">上一頁(yè)</a>

<%

for(intj=l;j<=intPageCount;j++){

if(currentPage!=j){

%>

<ahref="list.jsp?page=<%=j%>">[<%=j%>]</a>

<%

}else{

out.println(j);

%>

<ahref="List.jsp?page=<%=nextPage%>”>下一頁(yè)v/a><ahref=uList.jsp?page=<%=intPageC

最后頁(yè)

</a>

Xml方面

1、xml有哪些解析技術(shù)?區(qū)別是什么?

答:有DOM,SAX,STAX等

DOM:處理大型文件時(shí)其性能下降的非常厲害。這個(gè)問題是由DOM的樹結(jié)構(gòu)所造成的,這種

結(jié)構(gòu)占用的內(nèi)存較多,而且DOM必須在解析文件之前把整個(gè)文檔裝入內(nèi)存,適合對(duì)XML的隨

機(jī)訪問SAX:不現(xiàn)于DOM,SAX是事件驅(qū)動(dòng)型的XML解析方式。它順序讀取XML文件,不需

要一次全部裝載整個(gè)文件。當(dāng)遇到像文件開頭,文檔結(jié)束,或者標(biāo)簽開頭與標(biāo)簽結(jié)束時(shí),它會(huì)

觸發(fā)一個(gè)事件,用戶通過(guò)在其回調(diào)事件中寫入處理代碼來(lái)處理XML文件,適合對(duì)XML的順序

訪問

STAX:StreamingAPIforXML(StAX)

2、你在項(xiàng)目中用到了xml技術(shù)的哪些方面?如何實(shí)現(xiàn)的?

答:用到了數(shù)據(jù)存貯,信息配置兩方面。在做數(shù)據(jù)交換平臺(tái)時(shí),將不能數(shù)據(jù)源的數(shù)據(jù)組裝成XM

L文件,然后將XML文件壓縮打包加密后通過(guò)網(wǎng)絡(luò)傳送給接收者,接收解密與解壓縮后再同X

ML文件中還原相關(guān)信息進(jìn)行處理。在做軟件配置時(shí),利用XML可以很方便的進(jìn)行,軟件的各

種配置參數(shù)都存貯在XML文件中。

3、月打dom解析xml文件時(shí)如何解決中文問題?如何解析?

答:看如下代碼,用編碼方式加以解決

packagetest;

importjava.io.*;

publicclassDOMTest

privateStringinFile="c:\people.xml";

privateStringoutFile="c:\people.xmr;

publicstaticvoidmain(Stringargs[])

newDOMTest();

publicDOMTest()

try

javax.xml.parsers.DocumentBuilderbuilder=

javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocuinentBuilder();

org.w3c.dom.Documentdoc=builder.newDocument();

org.w3c.dom.Elementroot=doc.createElement("^!lf[5n);

org.w3c.dom.Elementwang=doc.createElement(,,I");

org.w3c.dom.Elementliu=doc.createElement("文『');

wang.appendChild(doc.createTextNode("^^ZE^ffi"));

root.appendChild(wang);

doc.appendChild(root);

javax.xml.transform.Transformertransformer=

javax.xml.transform.TransformerFactory.newInstance().newTransformer();

transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING,Hgb2312");

transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT,"yes");

transformer.transform(newjavax.xmI.transform.dom.DOMSource(doc),

new

javax.xml.transform.stream.StreamResuIt(outFile));

catch(Exceptione)

System.out.println(e.getMessage());

4、編程用JAVA解析XML的方式.

答:用SAX方式解析XML,XML文件如下:

<?xmlversion="1.0Mencoding=Hgb2312M?>

<person>

vname>王小明v/name〉

〈college〉信息學(xué)院v/college>

<telephone>6258113</telephono

vnotes>男,1955年生,博士,95年調(diào)入海南大學(xué)v/notes>

</person>

事件回調(diào)類SAXHandler.java

importjava.io.*;

importjava.util.Hashtable;

importorg.xml.sax.*;

publicclassSAXHandlerextendsHandlerBase

privateHashtabletable=newHashtable();

privateStringcurrentElement=null;

privateStringcurrentValue=null;

publicvoidsetTable(Hashtabletable)

this.table=table;

publicHashtablegetTable()

returntable;

publicvoidstartElement(Stringtag,AttributeListattrs)

throwsSAXException

currentElemenl=tag;

publicvoidcharacters(char[]ch,intstart,intlength)

throwsSAXException

currentValue=newString(ch,start,length);

publicvoidendElement(Stringname)throwsSAXException

if(currentElement.equals(name))

table.put(currentElenient,currentValue);

JSP內(nèi)容顯示源碼,SaxXml.jsp:

<HTML>

<HEAD>

vTITLE>剖析XML文件people.xmk/TITLE>

</HEAD>

<BODY>

<%@pageerrorPage=MErrPage.jspu

contentType=utext/html;charset=GB2312M%>

<%@pageimport=',java.io.*M%>

<%@pageimport="java.util.Hashtable"%>

<%@pageimport=',org.w3c.dom.*u%>

<%@pageimport="org.xml.sax.*H%>

<%@pageimport=ujavax.xml.parsers.SAXParserFactory"%>

<%@pageimport=',javax.xiYi1.parsers.SAXParseru%>

<%@pageimport=MSAXHandleru%>

<%

Filefile=newFile(Hc:\people.xm1");

FileReaderreader=newFileReader(file);

Parserparser;

SAXParserFactoryspf=SAXParserFactory.newInstance();

SAXParsersp=spf.newSAXParser();

SAXHandlerhandler=newSAXHandIer();

sp.parse(newInputSource(reader),handler);

HashtablehashTable=handler.getTable();

out.println(M<TABLEB0RDER=2>vCAPTI0N>教師信息表〈/CAPTION〉”);

oul.prinlln(“<TR><TD>姓名v/TD>"+H<TD>n+

(String)hashTable.get(newString(HnameM))+n</TDx/TR>u);

oul.prinlln("vTR>vTD:>學(xué)院v/TD>"+n<TD>H4-

(String)hashTable.get(newString(',college',))+"</TD></TR>H);

out.println(n<TR><TD>F&i5</TD>"+H<TD>n+

(String)hashTable.get(newString("telephone"))+"</TDx/TR>K);

oul.prinlln("vTR>vTD>備注v/TD>"+u<TD>n+

(String)hashTable.get(newString("notes"))+"</TDx/TR>°);

out.println("</TABLE>");

%>

</BODY>

</HTML>

EJB方面

1、EJB2.0有哪些內(nèi)容?分別用在什么場(chǎng)合?EJB2.0和EJB1.1的區(qū)別?

答:規(guī)范內(nèi)容包括Bean提供者,應(yīng)用程序裝配者,EJB容器,EJB配置工具,EJB服務(wù)提供

者,系統(tǒng)管理員。這里面,EJB容器是EJB之所以能夠運(yùn)行的核心。EJB容器管理著EJB的

創(chuàng)建,撤消,激活,去活,與數(shù)據(jù)庫(kù)的連接等等重要的核心工作。JSP,Servlet,EJBJND1JDB

C,JMS..…

2、EJB與JAVABEAN的區(qū)別?

答:JavaBean是可愛用的組件,對(duì)J

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論