2023年JAVA和C和C程序員筆試面試題目大全都在這了_第1頁
2023年JAVA和C和C程序員筆試面試題目大全都在這了_第2頁
2023年JAVA和C和C程序員筆試面試題目大全都在這了_第3頁
2023年JAVA和C和C程序員筆試面試題目大全都在這了_第4頁
2023年JAVA和C和C程序員筆試面試題目大全都在這了_第5頁
已閱讀5頁,還剩53頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

Java,C,C++程序員筆試面試的題目大全談?wù)刦inal,finally,finalize的區(qū)別:final:::修飾符(關(guān)鍵字)假如一個類被聲明為final,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被聲明為abstract的,又被聲明為final的。將變量或方法聲明為final,可以保證它們在使用中不被改變。被聲明為final的變量必須在聲明時給定初值,而在以后的引用中只能讀取,不可修改。被聲明為final的方法也同樣只能使用,不能重載finally:::再異常解決時提供finally塊來執(zhí)行任何清除操作。假如拋出一個異常,那么相匹配的catch子句就會執(zhí)行,然后控制就會進(jìn)入finally塊(假如有的話)。finalize:::方法名。Java技術(shù)允許使用finalize()方法在垃圾收集器將對象從內(nèi)存中清除出去之前做必要的清理工作。這個方法是由垃圾收集器在擬定這個對象沒有被引用時對這個對象調(diào)用的。它是在Object類中定義的,因此所有的類都繼承了它。子類覆蓋finalize()方法以整理系統(tǒng)資源或者執(zhí)行其他清理工作。finalize()方法是在垃圾收集器刪除對象之前對這個對象調(diào)用的。AnonymousInnerClass(匿名內(nèi)部類)是否可以extends(繼承)其它類,是否可以implements(實現(xiàn))interface(接口):匿名的內(nèi)部類是沒有名字的內(nèi)部類。能extends(繼承)其它類,但一個內(nèi)部類可以作為一個接口,由另一個內(nèi)部類實現(xiàn)。&和&&的區(qū)別:&是位運算符。&&是布爾邏輯運算符。HashMap和Hashtable的區(qū)別:都屬于Map接口的類,實現(xiàn)了將惟一鍵映射到特定的值上。HashMap類沒有分類或者排序。它允許一個null鍵和多個null值。Hashtable類似于HashMap,但是不允許null鍵和null值。它也比HashMap慢,由于它是同步的。都屬于Map接口的類,實現(xiàn)了將惟一鍵映射到特定的值上。HashMap類沒有分類或者排序。它允許一個null鍵和多個null值。Hashtable類似于HashMap,但是不允許null和null值。它也比HashMap慢,由于它是同步的。Hashtable繼承自Dictionary類,而HashMap是Java1.2引進(jìn)的Mapinterface的一個實現(xiàn)HashMap允許將null作為一個entry的key或者value,而Hashtable不允許尚有就是,HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。由于contains方法容易讓人引起誤解。最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多個線程訪問Hashtable時,不需要自己為它的方法實現(xiàn)同步,而HashMap就必須為之提供外同步。Hashtable和HashMap采用的hash/rehash算法都大約同樣,所以性能不會有很大的差異Collection和Collections的區(qū)別:Collections是個java.util下的類,它包具有各種有關(guān)集合操作的靜態(tài)方法。Collection是個java.util下的接口,它是各種集合結(jié)構(gòu)的父接口。GC是什么?為什么要有GC?(基礎(chǔ)):GC是垃圾收集器。Java程序員不用緊張內(nèi)存管理,由于垃圾收集器會自動進(jìn)行管理。要請求垃圾收集,可以調(diào)用下面的方法之一:System.gc()Runtime.getRuntime().gc()。Strings=newString("xyz");創(chuàng)建了幾個StringObject:兩個對象,一個是“xyx”,一個是指向“xyx”的引用對象s。Math.round(11.5)等于多少?Math.round(-11.5)等于多少:Math.round(11.5)返回(long)12,Math.round(-11.5)返回(long)-11。shorts1=1;s1=s1+1;有什么錯?shorts1=1;s1+=1;有什么錯:shorts1=1;s1=s1+1;有錯,s1是short型,s1+1是int型,不能顯式轉(zhuǎn)化為short型??尚薷臑閟1=(short)(s1+1)。shorts1=1;s1+=1對的。sleep()和wait()有什么區(qū)別:sleep()方法是使線程停止一段時間的方法。在sleep時間間隔期滿后,線程不一定立即恢復(fù)執(zhí)行。這是由于在那個時刻,其它線程也許正在運營并且沒有被調(diào)度為放棄執(zhí)行,除非(a)“醒來”的線程具有更高的優(yōu)先級(b)正在運營的線程由于其它因素而阻塞。wait()是線程交互時,假如線程對一個同步對象x發(fā)出一個wait()調(diào)用,該線程會暫停執(zhí)行,被調(diào)對象進(jìn)入等待狀態(tài),直到被喚醒或等待時間到。數(shù)組有沒有l(wèi)ength()這個方法?String有沒有length()這個方法:數(shù)組沒有l(wèi)ength()這個方法,有l(wèi)ength的屬性。String有l(wèi)ength()這個方法。Overload和Override的區(qū)別。Overloaded的方法是否可以改變返回值的類型:方法的重寫Overriding和重載Overloading是Java多態(tài)性的不同表現(xiàn)。重寫Overriding是父類與子類之間多態(tài)性的一種表現(xiàn),重載Overloading是一個類中多態(tài)性的一種表現(xiàn)。假如在子類中定義某方法與其父類有相同的名稱和參數(shù),我們說該方法被重寫(Overriding)。子類的對象使用這個方法時,將調(diào)用子類中的定義,對它而言,父類中的定義如同被“屏蔽”了。假如在一個類中定義了多個同名的方法,它們或有不同的參數(shù)個數(shù)或有不同的參數(shù)類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。Set里的元素是不能反復(fù)的,那么用什么方法來區(qū)分反復(fù)與否呢?是用==還是equals()?它們有何區(qū)別:Set里的元素是不能反復(fù)的,那么用iterator()方法來區(qū)分反復(fù)與否。equals()是判讀兩個Set是否相等。equals()和==方法決定引用值是否指向同一對象equals()在類中被覆蓋,為的是當(dāng)兩個分離的對象的內(nèi)容和類型相配的話,返回真值。給我一個你最常見到的runtimeexception:ArithmeticException(算法異常如0/9將拋出該異常),ArrayStoreException,BufferOverflowException,BufferUnderflowException,CannotRedoException,CannotUndoException,ClassCastException,(類轉(zhuǎn)換異常)CMMException,ConcurrentModificationException,DOMException,EmptyStackException,IllegalArgumentException,IllegalMonitorStateException,IllegalPathStateException,IllegalStat(yī)eException,ImagingOpException,IndexOutOfBoundsException(數(shù)組越界異常),MissingResourceException,NegativeArraySizeException(數(shù)組定義了一個負(fù)數(shù)異常),NoSuchElementException,NullPointerException,(空的指向異常)ProfileDat(yī)aException,ProviderException,RasterFormatException,SecurityException,SystemException,(系統(tǒng)異常)UndeclaredThrowableException,UnmodifiableSetException,UnsupportedOperationException。error和exception有什么區(qū)別:error表達(dá)恢復(fù)不是不也許但很困難的情況下的一種嚴(yán)重問題。比如說內(nèi)存溢出。不也許指望程序能解決這樣的情況。exception表達(dá)一種設(shè)計或?qū)崿F(xiàn)問題。也就是說,它表達(dá)假如程序運營正常,從不會發(fā)生的情況。List,Set,Map是否繼承自Collection接口:List,Set是。Map不是。abstractclass和interface有什么區(qū)別:聲明方法的存在而不去實現(xiàn)它的類被叫做抽象類(abstractclass),它用于要創(chuàng)建一個體現(xiàn)某些基本行為的類,并為該類聲明方法,但不能在該類中實現(xiàn)該類的情況。不能創(chuàng)建abstract類的實例。然而可以創(chuàng)建一個變量,其類型是一個抽象類,并讓它指向具體子類的一個實例。不能有抽象構(gòu)造函數(shù)或抽象靜態(tài)方法。Abstract類的子類為它們父類中的所有抽象方法提供實現(xiàn),否則它們也是抽象類為。取而代之,在子類中實現(xiàn)該方法。知道其行為的其它類可以在類中實現(xiàn)這些方法。接口(interface)是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過實現(xiàn)這樣的接口而獲得。接口中的所有方法都是抽象的,沒有一個有程序體。接口只可以定義staticfinal成員變量。接口的實現(xiàn)與子類相似,除了該實現(xiàn)類不能從接口定義中繼承行為。當(dāng)類實現(xiàn)特殊接口時,它定義(即將程序體給予)所有這種接口的方法。然后,它可以在實現(xiàn)了該接口的類的任何對象上調(diào)用接口的方法。由于有抽象類,它允許使用接口名作為引用變量的類型。通常的動態(tài)聯(lián)編將生效。引用可以轉(zhuǎn)換到接口類型或從接口類型轉(zhuǎn)換,instanceof運算符可以用來決定某對象的類是否實現(xiàn)了接口。接口是否可繼承接口?抽象類是否可實現(xiàn)(implements)接口?抽象類是否可繼承實體類(concreteclass):接口可以繼承接口。抽象類可以實現(xiàn)(implements)接口,抽象類是否可繼承實體類,但前提是實體類必須有明確的構(gòu)造函數(shù)?!飭右粋€線程是用run()還是start():啟動一個線程是調(diào)用start()方法,使線程所代表的虛擬解決機處在可運營狀態(tài),這意味著它可以由JVM調(diào)度并執(zhí)行。這并不意味著線程就會立即運營。run()方法可以產(chǎn)生必須退出的標(biāo)志來停止一個線程。構(gòu)造器Constructor是否可被override:構(gòu)造器Constructor不能被繼承,因此不能重寫Overriding,但可以被重載Overloading。try{}里有一個return語句,那么緊跟在這個try后的finally{}里的code會不會被執(zhí)行,什么時候被執(zhí)行,在return前還是后:會執(zhí)行,在return前執(zhí)行。兩個對象值相同(x.equals(y)==true),但卻可有不同的hashcode,這句話對不對:不對,有相同的hashcode。當(dāng)一個對象被當(dāng)作參數(shù)傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結(jié)果,那么這里到底是值傳遞還是引用傳遞:是值傳遞。Java編程語言只由值傳遞參數(shù)。當(dāng)一個對象實例作為一個參數(shù)被傳遞到方法中時,參數(shù)的值就是對該對象的引用。對象的內(nèi)容可以在被調(diào)用的方法中改變,但對象的引用是永遠(yuǎn)不會改變的。swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上:switch(expr1)中,expr1是一個整數(shù)表達(dá)式。因此傳遞給switch和case語句的參數(shù)應(yīng)當(dāng)是int、short、char或者byte。long,string都不能作用于swtich。編程題:寫一個Singleton出來:Singleton模式重要作用是保證在Java應(yīng)用程序中,一個類Class只有一個實例存在。一般Singleton模式通常有幾種種形式:第一種形式:定義一個類,它的構(gòu)造函數(shù)為private的,它有一個static的private的該類變量,在類初始化時實例話,通過一個public的getInstance方法獲取對它的引用,繼而調(diào)用其中的方法。publicclassSingleton{privateSingleton(){}//在自己內(nèi)部定義自己一個實例,是不是很奇怪?//注意這是privat(yī)e只供內(nèi)部調(diào)用privatestat(yī)icSingletoninstance=newSingleton();//這里提供了一個供外部訪問本class的靜態(tài)方法,可以直接訪問publicstaticSingletongetInstance(){returninstance;}}第二種形式:publicclassSingleton{privatestaticSingletoninstance=null;publicstaticsynchronizedSingletongetInstance(){//這個方法比上面有所改善,不用每次都進(jìn)行生成對象,只是第一次//使用時生成實例,提高了效率!if(instance==null)instance=newSingleton();returninstance;}}其他形式:定義一個類,它的構(gòu)造函數(shù)為privat(yī)e的,所有方法為static的。一般認(rèn)為第一種形式要更加安全些。Hashtable和HashMap的區(qū)別:Hashtable繼承自Dictionary類,而HashMap是Java1.2引進(jìn)的Mapinterface的一個實現(xiàn)HashMap允許將null作為一個entry的key或者value,而Hashtable不允許尚有就是,HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。由于contains方法容易讓人引起誤解。最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多個線程訪問Hashtable時,不需要自己為它的方法實現(xiàn)同步,而HashMap就必須為之提供外同步。Hashtable和HashMap采用的hash/rehash算法都大約同樣,所以性能不會有很大的差異作用域public,private,protected,以及不寫時的區(qū)別:作用域當(dāng)前類同一package子孫類其他packagepublic√√√√protected√√√×friendly√√××private√×××不寫時默認(rèn)為friendly。ArrayList和Vector的區(qū)別,HashMap和Hashtable的區(qū)別:答:就ArrayList與Vector重要從二方面來說.一.同步性:Vector是線程安全的,也就是說是同步的,而ArrayList是線程序不安全的,不是同步的二.數(shù)據(jù)增長:當(dāng)需要增長時,Vector默認(rèn)增長為本來一倍,而ArrayList卻是本來的一半就HashMap與HashTable重要從三方面來說。一.歷史因素:Hashtable是基于陳舊的Dictionary類的,HashMap是Java1.2引進(jìn)的Map接口的一個實現(xiàn)二.同步性:Hashtable是線程安全的,也就是說是同步的,而HashMap是線程不安全的,不是同步的三.值:只有HashMap可以讓你將空值作為一個表的條目的key或value。char型變量中能不能存貯一個中文漢字?為什么:答:是可以定義成為一個中文的,由于java中以unicode編碼,一個char占16個字節(jié),所以放一個中文是沒問題的。介紹JAVA中的CollectionFrameWork(涉及如何寫自己的數(shù)據(jù)結(jié)構(gòu)):答:CollectionFrameWork如下:Collection├List│├LinkedList│├ArrayList│└Vector│└Stack└SetMap├Hashtable├HashMap└WeakHashMapCollection是最基本的集合接口,一個Collection代表一組Object,即Collection的元素(Elements)Map提供key到value的映射。jsp有哪些內(nèi)置對象?作用分別是什么:答:JSP共有以下9種基本內(nèi)置組件(可與ASP的6種內(nèi)部組件相相應(yīng)):request用戶端請求,此請求會包含來自GET/POST請求的參數(shù)response網(wǎng)頁傳回用戶端的回應(yīng)pageContext網(wǎng)頁的屬性是在這里管理session與請求有關(guān)的會話期applicationservlet正在執(zhí)行的內(nèi)容out用來傳送回應(yīng)的輸出configservlet的構(gòu)架部件pageJSP網(wǎng)頁自身exception針對錯誤網(wǎng)頁,未捕獲的例外。jsp有哪些動作?作用分別是什么:答:JSP共有以下6種基本動作jsp:include:在頁面被請求的時候引入一個文獻(xiàn)。jsp:useBean:尋找或者實例化一個JavaBean。jsp:setProperty:設(shè)立JavaBean的屬性。jsp:getProperty:輸出某個JavaBean的屬性。jsp:forward:把請求轉(zhuǎn)到一個新的頁面。jsp:plugin:根據(jù)瀏覽器類型為Java插件生成OBJECT或EMBED標(biāo)記。JSP中動態(tài)INCLUDE與靜態(tài)INCLUDE的區(qū)別:答:動態(tài)INCLUDE用jsp:include動作實現(xiàn)<jsp:includepage="included.jsp"flush="true"/>它總是會檢查所含文獻(xiàn)中的變化,適合用于包含動態(tài)頁面,并且可以帶參數(shù)靜態(tài)INCLUDE用include偽碼實現(xiàn),定不會檢查所含文獻(xiàn)的變化,合用于包含靜態(tài)頁面<%@includefile="included.htm"%>。兩種跳轉(zhuǎn)方式分別是什么?有什么區(qū)別:答:有兩種,分別為:<jsp:includepage="included.jsp"flush="true"><jsp:forwardpage="nextpage.jsp"/>前者頁面不會轉(zhuǎn)向include所指的頁面,只是顯示該頁的結(jié)果,主頁面還是本來的頁面。執(zhí)行完后還會回來,相稱于函數(shù)調(diào)用。并且可以帶參數(shù).后者完全轉(zhuǎn)向新頁面,不會再回來。相稱于goto語句。說一說Servlet的生命周期:答:servlet有良好的生存期的定義,涉及加載和實例化、初始化、解決請求以及服務(wù)結(jié)束。這個生存期由javax.servlet.Servlet接口的init,service和destroy方法表達(dá)。JAVASERVLETAPI中forward()與redirect()的區(qū)別:答:前者僅是容器中控制權(quán)的轉(zhuǎn)向,在客戶端瀏覽器地址欄中不會顯示出轉(zhuǎn)向后的地址;后者則是完全的跳轉(zhuǎn),瀏覽器將會得到跳轉(zhuǎn)的地址,并重新發(fā)送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉(zhuǎn)后的鏈接地址。所以,前者更加高效,在前者可以滿足需要時,盡量使用forward()方法,并且,這樣也有助于隱藏實際的鏈接。在有些情況下,比如,需要跳轉(zhuǎn)到一個其它服務(wù)器上的資源,則必須使用sendRedirect()方法。Servlet的基本架構(gòu):publicclassServletNameextendsHttpServlet{publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{}publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{}}也許會讓你寫一段Jdbc連Oracle的程序,并實現(xiàn)數(shù)據(jù)查詢:答:程序如下:packagehello.ant;importjava.sql.*;publicclassjdbc{StringdbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl";StringtheUser="admin";StringthePw="manager";Connectionc=null;Statementconn;ResultSetrs=null;publicjdbc(){try{Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();c=DriverManager.getConnection(dbUrl,theUser,thePw);conn=c.creat(yī)eStatement();}catch(Exceptione){e.printStackTrace();}}publicbooleanexecuteUpdate(Stringsql){try{conn.executeUpdate(sql);returntrue;}catch(SQLExceptione){e.printStackTrace();returnfalse;}}publicResultSetexecuteQuery(Stringsql){rs=null;try{rs=conn.executeQuery(sql);}catch(SQLExceptione){e.printStackTrace();}returnrs;}publicvoidclose(){try{conn.close();c.close();}catch(Exceptione){e.printStackTrace();}}publicstat(yī)icvoidmain(String[]args){ResultSetrs;jdbcconn=newjdbc();rs=conn.executeQuery("select*fromtest");try{while(rs.next()){System.out.println(rs.getString("id"));System.out.println(rs.getString("name"));}}cat(yī)ch(Exceptione){e.printStackTrace();}}}Class.forName的作用?為什么要用:答:調(diào)用該訪問返回一個以字符串指定類名的類的對象。Jdo是什么:答:JDO是Java對象持久化的新的規(guī)范,為javadataobject的簡稱,也是一個用于存取某種數(shù)據(jù)倉庫中的對象的標(biāo)準(zhǔn)化API。JDO提供了透明的對象存儲,因此對開發(fā)人員來說,存儲數(shù)據(jù)對象完全不需要額外的代碼(如JDBCAPI的使用)。這些繁瑣的例行工作已經(jīng)轉(zhuǎn)移到JDO產(chǎn)品提供商身上,使開發(fā)人員解脫出來,從而集中時間和精力在業(yè)務(wù)邏輯上。此外,JDO很靈活,由于它可以在任何數(shù)據(jù)底層上運營。JDBC只是面向關(guān)系數(shù)據(jù)庫(RDBMS)JDO更通用,提供到任何數(shù)據(jù)底層的存儲功能,比如關(guān)系數(shù)據(jù)庫、文獻(xiàn)、XML以及對象數(shù)據(jù)庫(ODBMS)等等,使得應(yīng)用可移植性更強。xml有哪些解析技術(shù)?區(qū)別是什么:答:有DOM,SAX,STAX等DOM:解決大型文獻(xiàn)時其性能下降的非常厲害。這個問題是由DOM的樹結(jié)構(gòu)所導(dǎo)致的,這種結(jié)構(gòu)占用的內(nèi)存較多,并且DOM必須在解析文獻(xiàn)之前把整個文檔裝入內(nèi)存,適合對XML的隨機訪問SAX:不現(xiàn)于DOM,SAX是事件驅(qū)動型的XML解析方式。它順序讀取XML文獻(xiàn),不需要一次所有裝載整個文獻(xiàn)。當(dāng)碰到像文獻(xiàn)開頭,文檔結(jié)束,或者標(biāo)簽開頭與標(biāo)簽結(jié)束時,它會觸發(fā)一個事件,用戶通過在其回調(diào)事件中寫入解決代碼來解決XML文獻(xiàn),適合對XML的順序訪問STAX:StreamingAPIforXML(StAX)。你在項目中用到了xml技術(shù)的哪些方面?如何實現(xiàn)的:答:用到了數(shù)據(jù)存貯,信息配置兩方面。在做數(shù)據(jù)互換平臺時,不能將數(shù)據(jù)源的數(shù)據(jù)組裝成XML文獻(xiàn),然后將XML文獻(xiàn)壓縮打包加密后通過網(wǎng)絡(luò)傳送給接受者,接受解密與解壓縮后再同XML文獻(xiàn)中還原相關(guān)信息進(jìn)行解決。在做軟件配置時,運用XML可以很方便的進(jìn)行,軟件的各種配置參數(shù)都存貯在XML文獻(xiàn)中。用jdom解析xml文獻(xiàn)時如何解決中文問題?如何解析:答:看如下代碼,用編碼方式加以解決packagetest;importjava.io.*;publicclassDOMTest{privateStringinFile="c:\people.xml";privateStringoutFile="c:\people.xml";publicstaticvoidmain(Stringargs[]){newDOMTest();}publicDOMTest(){try{javax.xml.parsers.DocumentBuilderbuilder=j(luò)avax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();org.w3c.dom.Documentdoc=builder.newDocument();org.w3c.dom.Elementroot=doc.createElement("老師");org.w3c.dom.Elementwang=doc.createElement("王");org.w3c.dom.Elementliu=doc.createElement("劉");wang.appendChild(doc.creat(yī)eTextNode("我是王老師"));root.appendChild(wang);doc.appendChild(root);javax.xml.transform.Transformertransformer=j(luò)avax.xml.transform.TransformerFactory.newInstance().newTransformer();transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING,"gb2312");transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT,"yes");transformer.transform(newjavax.xml.transform.dom.DOMSource(doc),newjavax.xml.transform.stream.StreamResult(outFile));}cat(yī)ch(Exceptione){System.out.println(e.getMessage());}}}編程用JAVA解析XML的方式:答:用SAX方式解析XML,XML文獻(xiàn)如下:<?xmlversion="1.0"encoding="gb2312"?><person><name>王小明</name><college>信息學(xué)院</college><telephone>6258113</telephone><notes>男,1955年生,博士,95年調(diào)入海南大學(xué)</notes></person>事件回調(diào)類SAXHandler.javaimportjava.io.*;importjava.util.Hashtable;importorg.xml.sax.*;publicclassSAXHandlerextendsHandlerBase{privateHashtabletable=newHashtable();privat(yī)eStringcurrentElement=null;privateStringcurrentValue=null;publicvoidsetTable(Hashtabletable){this.table=table;}publicHashtablegetTable(){returntable;}publicvoidstartElement(Stringtag,AttributeListattrs)throwsSAXException{currentElement=tag;}publicvoidcharacters(char[]ch,intstart,intlength)throwsSAXException{currentValue=newString(ch,start,length);}publicvoidendElement(Stringname)throwsSAXException{if(currentElement.equals(name))table.put(currentElement,currentValue);}}JSP內(nèi)容顯示源碼,SaxXml.jsp:<HTML><HEAD><TITLE>剖析XML文獻(xiàn)people.xml</TITLE></HEAD><BODY><%@pageerrorPage="ErrPage.jsp"contentType="text/html;charset=GB2312"%><%@pageimport="java.io.*"%><%@pageimport="java.util.Hashtable"%><%@pageimport="org.w3c.dom.*"%><%@pageimport="org.xml.sax.*"%><%@pageimport="javax.xml.parsers.SAXParserFactory"%><%@pageimport="javax.xml.parsers.SAXParser"%><%@pageimport="SAXHandler"%><%Filefile=newFile("c:\people.xml");FileReaderreader=newFileReader(file);Parserparser;SAXParserFactoryspf=SAXParserFactory.newInstance();SAXParsersp=spf.newSAXParser();SAXHandlerhandler=newSAXHandler();sp.parse(newInputSource(reader),handler);HashtablehashTable=handler.getTable();out.println("<TABLEBORDER=2><CAPTION>教師信息表</CAPTION>");out.println("<TR><TD>姓名</TD>"+"<TD>"+(String)hashTable.get(newString("name"))+"</TD></TR>");out.println("<TR><TD>學(xué)院</TD>"+"<TD>"+(String)hashTable.get(newString("college"))+"</TD></TR>");out.println("<TR><TD>電話</TD>"+"<TD>"+(String)hashTable.get(newString("telephone"))+"</TD></TR>");out.println("<TR><TD>備注</TD>"+"<TD>"+(String)hashTable.get(newString("notes"))+"</TD></TR>");out.println("</TABLE>");%></BODY></HTML>EJB與JAVABEAN的區(qū)別:答:JavaBean是可復(fù)用的組件,對JavaBean并沒有嚴(yán)格的規(guī)范,理論上講,任何一個Java類都可以是一個Bean。但通常情況下,由于JavaBean是被容器所創(chuàng)建(如Tomcat)的,所以JavaBean應(yīng)具有一個無參的構(gòu)造器,此外,通常JavaBean還要實現(xiàn)Serializable接口用于實現(xiàn)Bean的持久性。JavaBean事實上相稱于微軟COM模型中的本地進(jìn)程內(nèi)COM組件,它是不能被跨進(jìn)程訪問的。EnterpriseJavaBean相稱于DCOM,即分布式組件。它是基于Java的遠(yuǎn)程方法調(diào)用(RMI)技術(shù)的,所以EJB可以被遠(yuǎn)程訪問(跨進(jìn)程、跨計算機)。但EJB必須被部署在諸如Webspere、WebLogic這樣的容器中,EJB客戶從不直接訪問真正的EJB組件,而是通過其容器訪問。EJB容器是EJB組件的代理,EJB組件由容器所創(chuàng)建和管理??蛻敉ㄟ^容器來訪問真正的EJB組件。EJB的基本架構(gòu):答:一個EJB涉及三個部分:RemoteInterface接口的代碼packageBeans;importjavax.ejb.EJBObject;importjava.rmi.RemoteException;publicinterfaceAddextendsEJBObject{//somemethoddeclare}HomeInterface接口的代碼packageBeans;importjava.rmi.RemoteException;importjaax.ejb.CreateException;importjavax.ejb.EJBHome;publicinterfaceAddHomeextendsEJBHome{//somemethoddeclare}EJB類的代碼packageBeans;importjava.rmi.RemoteException;importjavax.ejb.SessionBean;importjavx.ejb.SessionContext;publicclassAddBeanImplementsSessionBean{//somemethoddeclare}MVC的各個部分都有那些技術(shù)來實現(xiàn)?如何實現(xiàn):答:MVC是Model-View-Controller的簡寫。"Model"代表的是應(yīng)用的業(yè)務(wù)邏輯(通過JavaBean,EJB組件實現(xiàn)),"View"是應(yīng)用的表達(dá)面(由JSP頁面產(chǎn)生),"Controller"是提供應(yīng)用的解決過程控制(一般是一個Servlet),通過這種設(shè)計模型把應(yīng)用邏輯,解決過程和顯示邏輯提成不同的組件實現(xiàn)。這些組件可以進(jìn)行交互和重用。J2EE是什么:答:Je22是Sun公司提出的多層(multi-diered),分布式(distributed),基于組件(component-base)的公司級應(yīng)用模型(enterprieseapplicationmodel).在這樣的一個應(yīng)用系統(tǒng)中,可按照功能劃分為不同的組件,這些組件又可在不同計算機上,并且處在相應(yīng)的層次(tier)中。所屬層次涉及客戶層(clietntier)組件,web層和組件,Business層和組件,公司信息系統(tǒng)(EIS)層。WEBSERVICE名詞解釋。JSWDL開發(fā)包的介紹。JAXP、JAXM的解釋。SOAP、UDDI,WSDL解釋:答:WebService描述語言WSDLSOAP即簡樸對象訪問協(xié)議(SimpleObjectAccessProtocol),它是用于互換XML編碼信息的輕量級協(xié)議。UDDI的目的是為電子商務(wù)建立標(biāo)準(zhǔn);UDDI是一套基于Web的、分布式的、為WebService提供的、信息注冊中心的實現(xiàn)標(biāo)準(zhǔn)規(guī)范,同時也包含一組使公司能將自身提供的WebService注冊,以使別的公司可以發(fā)現(xiàn)的訪問協(xié)議的實現(xiàn)標(biāo)準(zhǔn)。STRUTS的應(yīng)用(如STRUTS架構(gòu)):答:Struts是采用JavaServlet/JavaServerPages技術(shù),開發(fā)Web應(yīng)用程序的開放源碼的framework。采用Struts能開發(fā)出基于MVC(Model-View-Controller)設(shè)計模式的應(yīng)用構(gòu)架。Struts有如下的重要功能:一.包含一個controllerservlet,能將用戶的請求發(fā)送到相應(yīng)的Action對象。二.JSP自由tag庫,并且在controllerservlet中提供關(guān)聯(lián)支持,幫助開發(fā)員創(chuàng)建交互式表單應(yīng)用。三.提供了一系列實用對象:XML解決、通過JavareflectionAPIs自動解決JavaBeans屬性、國際化的提醒和消息。開發(fā)中都用到了那些設(shè)計模式?用在什么場合:答:每個模式都描述了一個在我們的環(huán)境中不斷出現(xiàn)的問題,然后描述了該問題的解決方案的核心。通過這種方式,你可以無數(shù)次地使用那些已有的解決方案,無需在反復(fù)相同的工作。重要用到了MVC的設(shè)計模式。用來開發(fā)JSP/Servlet或者J2EE的相關(guān)應(yīng)用。簡樸工廠模式等。存儲過程和函數(shù)的區(qū)別:存儲過程是用戶定義的一系列sql語句的集合,涉及特定表或其它對象的任務(wù),用戶可以調(diào)用存儲過程,而函數(shù)通常是數(shù)據(jù)庫已定義的方法,它接受參數(shù)并返回某種類型的值并且不涉及特定用戶表。事務(wù)是什么:事務(wù)是作為一個邏輯單元執(zhí)行的一系列操作,一個邏輯工作單元必須有四個屬性,稱為ACID(原子性、一致性、隔離性和持久性)屬性,只有這樣才干成為一個事務(wù):原子性:事務(wù)必須是原子工作單元;對于其數(shù)據(jù)修改,要么全都執(zhí)行,要么全都不執(zhí)行。一致性:事務(wù)在完畢時,必須使所有的數(shù)據(jù)都保持一致狀態(tài)。在相關(guān)數(shù)據(jù)庫中,所有規(guī)則都必須應(yīng)用于事務(wù)的修改,以保持所有數(shù)據(jù)的完整性。事務(wù)結(jié)束時,所有的內(nèi)部數(shù)據(jù)結(jié)構(gòu)(如B樹索引或雙向鏈表)都必須是對的的。隔離性:由并發(fā)事務(wù)所作的修改必須與任何其它并發(fā)事務(wù)所作的修改隔離。事務(wù)查看數(shù)據(jù)時數(shù)據(jù)所處的狀態(tài),要么是另一并發(fā)事務(wù)修改它之前的狀態(tài),要么是另一事務(wù)修改它之后的狀態(tài),事務(wù)不會查看中間狀態(tài)的數(shù)據(jù)。這稱為可串行性,由于它可以重新裝載起始數(shù)據(jù),并且回放一系列事務(wù),以使數(shù)據(jù)結(jié)束時的狀態(tài)與原始事務(wù)執(zhí)行的狀態(tài)相同。持久性:事務(wù)完畢之后,它對于系統(tǒng)的影響是永久性的。該修改即使出現(xiàn)系統(tǒng)故障也將一直保持。游標(biāo)的作用?如何知道游標(biāo)已經(jīng)到了最后:游標(biāo)用于定位結(jié)果集的行,通過判斷全局變量@@FETCH_STATUS可以判斷是否到了最后,通常此變量不等于0表達(dá)犯錯或到了最后。觸發(fā)器分為事前觸發(fā)和事后觸發(fā),這兩種觸發(fā)有和區(qū)別。語句級觸發(fā)和行級觸發(fā)有何區(qū)別:事前觸發(fā)器運營于觸發(fā)事件發(fā)生之前,而事后觸發(fā)器運營于觸發(fā)事件發(fā)生之后。通常事前觸發(fā)器可以獲取事件之前和新的字段值。語句級觸發(fā)器可以在語句執(zhí)行前或后執(zhí)行,而行級觸發(fā)在觸發(fā)器所影響的每一行觸發(fā)一次。bean實例的生命周期:對于StatelessSessionBean、EntityBean、MessageDrivenBean一般存在緩沖池管理,而對于EntityBean和StatefullSessionBean存在Cache管理,通常包含創(chuàng)建實例,設(shè)立上下文、創(chuàng)建EJBObject(create)、業(yè)務(wù)方法調(diào)用、remove等過程,對于存在緩沖池管理的Bean,在create之后實例并不從內(nèi)存清除,而是采用緩沖池調(diào)度機制不斷重用實例,而對于存在Cache管理的Bean則通過激活和去激活機制保持Bean的狀態(tài)并限制內(nèi)存中實例數(shù)量。remote接口和home接口重要作用:remote接口定義了業(yè)務(wù)方法,用于EJB客戶端調(diào)用業(yè)務(wù)方法home接口是EJB工廠用于創(chuàng)建和移除查找EJB實例。客服端調(diào)用EJB對象的幾個基本環(huán)節(jié):一、設(shè)立JNDI服務(wù)工廠以及JNDI服務(wù)地址系統(tǒng)屬性。二、查找Home接口。三、從Home接口調(diào)用Create方法創(chuàng)建Remote接口。四、通過Remote接口調(diào)用其業(yè)務(wù)方法。什么時候用assert:斷言是一個包含布爾表達(dá)式的語句,在執(zhí)行這個語句時假定該表達(dá)式為true。假如表達(dá)式計算為false,那么系統(tǒng)會報告一個AssertionError。它用于調(diào)試目的:assert(a>0);//throwsanAssertionErrorifa<=0斷言可以有兩種形式:assertExpression1;assertExpression1:Expression2;Expression1應(yīng)當(dāng)總是產(chǎn)生一個布爾值。Expression2可以是得出一個值的任意表達(dá)式。這個值用于生成顯示更多調(diào)試信息的String消息。斷言在默認(rèn)情況下是禁用的。要在編譯時啟用斷言,需要使用source1.4標(biāo)記:javac-source1.4Test.java要在運營時啟用斷言,可使用-enableassertions或者-ea標(biāo)記。要在運營時選擇禁用斷言,可使用-da或者-disableassertions標(biāo)記。要系統(tǒng)類中啟用斷言,可使用-esa或者-dsa標(biāo)記。還可以在包的基礎(chǔ)上啟用或者禁用斷言。可以在預(yù)計正常情況下不會到達(dá)的任何位置上放置斷言。斷言可以用于驗證傳遞給私有方法的參數(shù)。但是,斷言不應(yīng)當(dāng)用于驗證傳遞給公有方法的參數(shù),由于不管是否啟用了斷言,公有方法都必須檢查其參數(shù)。但是,既可以在公有方法中,也可以在非公有方法中運用斷言測試后置條件。此外,斷言不應(yīng)當(dāng)以任何方式改變程序的狀態(tài)。是否可以繼承String類:String類是final類故不可以繼承。面向?qū)ο蟮奶匦杂心男┓矫?抽象:抽象就是忽略一個主題中與當(dāng)前目的無關(guān)的那些方面,以便更充足地注意與當(dāng)前目的有關(guān)的方面。抽象并不打算了解所有問題,而只是選擇其中的一部分,暫時不用部分細(xì)節(jié)。抽象涉及兩個方面,一是過程抽象,二是數(shù)據(jù)抽象。繼承:繼承是一種聯(lián)結(jié)類的層次模型,并且允許和鼓勵類的重用,它提供了一種明確表述共性的方法。對象的一個新類可以從現(xiàn)有的類中派生,這個過程稱為類繼承。新類繼承了原始類的特性,新類稱為原始類的派生類(子類),而原始類稱為新類的基類(父類)。派生類可以從它的基類那里繼承方法和實例變量,并且類可以修改或增長新的方法使之更適合特殊的需要。封裝:封裝是把過程和數(shù)據(jù)包圍起來,對數(shù)據(jù)的訪問只能通過已定義的界面。面向?qū)ο笥嬎闶加谶@個基本概念,即現(xiàn)實世界可以被描繪成一系列完全自治、封裝的對象,這些對象通過一個受保護(hù)的接口訪問其他對象。多態(tài)性:多態(tài)性是指允許不同類的對象對同一消息作出響應(yīng)。多態(tài)性涉及參數(shù)化多態(tài)性和包含多態(tài)性。多態(tài)性語言具有靈活、抽象、行為共享、代碼共享的優(yōu)勢,很好的解決了應(yīng)用程序函數(shù)同名問題。String是最基本的數(shù)據(jù)類型嗎:基本數(shù)據(jù)類型涉及byte、int、char、long、float(yī)、double、boolean和short。java.lang.String類是final類型的,因此不可以繼承這個類、不能修改這個類。為了提高效率節(jié)省空間,我們應(yīng)當(dāng)用StringBuffer類。String和StringBuffer的區(qū)別:JAVA平臺提供了兩個類:String和StringBuffer,它們可以儲存和操作字符串,即包含多個字符的字符數(shù)據(jù)。這個String類提供了數(shù)值不可改變的字符串。而這個StringBuffer類提供的字符串進(jìn)行修改。當(dāng)你知道字符數(shù)據(jù)要改變的時候你就可以使用StringBuffer。典型地,你可以使用StringBuffers來動態(tài)構(gòu)造字符數(shù)據(jù)。說出ArrayList,Vector,LinkedList的存儲性能和特性:ArrayList和Vector都是使用數(shù)組方式存儲數(shù)據(jù),此數(shù)組元素數(shù)大于實際存儲的數(shù)據(jù)以便增長和插入元素,它們都允許直接按序號索引元素,但是插入元素要涉及數(shù)組元素移動等內(nèi)存操作,所以索引數(shù)據(jù)快而插入數(shù)據(jù)慢,Vector由于使用了synchronized方法(線程安全),通常性能上較ArrayList差,而LinkedList使用雙向鏈表實現(xiàn)存儲,按序號索引數(shù)據(jù)需要進(jìn)行前向或后向遍歷,但是插入數(shù)據(jù)時只需要記錄本項的前后項即可,所以插入速度較快。同步和異步有何異同,在什么情況下分別使用他們?舉例說明。假如數(shù)據(jù)將在線程間共享。例如正在寫的數(shù)據(jù)以后也許被另一個線程讀到,或者正在讀的數(shù)據(jù)也許已經(jīng)被另一個線程寫過了,那么這些數(shù)據(jù)就是共享數(shù)據(jù),必須進(jìn)行同步存取。當(dāng)應(yīng)用程序在對象上調(diào)用了一個需要花費很長時間來執(zhí)行的方法,并且不希望讓程序等待方法的返回時,就應(yīng)當(dāng)使用異步編程,在很多情況下采用異步途徑往往更有效率。heap和stack有什么區(qū)別:棧是一種線形集合,其添加和刪除元素的操作應(yīng)在同一段完畢。棧按照后進(jìn)先出的方式進(jìn)行解決。堆是棧的一個組成元素。EJB與JAVABEAN的區(qū)別:javaBean是可復(fù)用的組件,對JavaBean并沒有嚴(yán)格的規(guī)范,理論上講,任何一個Java類都可以是一個Bean。但通常情況下,由于JavaBean是被容器所創(chuàng)建(如Tomcat)的,所以JavaBean應(yīng)具有一個無參的構(gòu)造器,此外,通常JavaBean還要實現(xiàn)Serializable接口用于實現(xiàn)Bean的持久性。JavaBean事實上相稱于微軟COM模型中的本地進(jìn)程內(nèi)COM組件,它是不能被跨進(jìn)程訪問的。EnterpriseJavaBean相稱于DCOM,即分布式組件。它是基于Java的遠(yuǎn)程方法調(diào)用(RMI)技術(shù)的,所以EJB可以被遠(yuǎn)程訪問(跨進(jìn)程、跨計算機)。但EJB必須被部署在諸如Webspere、WebLogic這樣的容器中,EJB客戶從不直接訪問真正的EJB組件,而是通過其容器訪問。EJB容器是EJB組件的代理,EJB組件由容器所創(chuàng)建和管理。客戶通過容器來訪問真正的EJB組件。StaticNestedClass和InnerClass的不同:StaticNestedClass是被聲明為靜態(tài)(static)的內(nèi)部類,它可以不依賴于外部類實例被實例化。而通常的內(nèi)部類需要在外部類實例化后才干實例化。Java的接口和C++的虛類的相同和不同處:由于Java不支持多繼承,而有也許某個類或?qū)ο笠褂梅謩e在幾個類或?qū)ο罄锩娴姆椒ɑ驅(qū)傩?現(xiàn)有的單繼承機制就不能滿足規(guī)定。與繼承相比,接口有更高的靈活性,由于接口中沒有任何實現(xiàn)代碼。當(dāng)一個類實現(xiàn)了接口以后,該類要實現(xiàn)接口里面所有的方法和屬性,并且接口里面的屬性在默認(rèn)狀態(tài)下面都是publicstatic,所有方法默認(rèn)情況下是public.一個類可以實現(xiàn)多個接口。你所知道的集合類都有哪些?重要方法:最常用的集合類是List和Map。List的具體實現(xiàn)涉及ArrayList和Vector,它們是可變大小的列表,比較適合構(gòu)建、存儲和操作任何類型對象的元素列表。List合用于按數(shù)值索引訪問元素的情形。Map提供了一個更通用的元素存儲方法。Map集合類用于存儲元素對(稱作“鍵”和“值”),其中每個鍵映射到一個值。JSP的內(nèi)置對象及方法:request表達(dá)HttpServletRequest對象。它包含了有關(guān)瀏覽器請求的信息,并且提供了幾個用于獲取cookie,header,和session數(shù)據(jù)的有用的方法,response表達(dá)HttpServletResponse對象,并提供了幾個用于設(shè)立送回瀏覽器的響應(yīng)的方法(如cookies,頭信息等).out對象是javax.jsp.JspWriter的一個實例,并提供了幾個方法使你能用于向瀏覽器回送輸出結(jié)果。pageContext表達(dá)一個javax.servlet.jsp.PageContext對象。它是用于方便存取各種范圍的名字空間、servlet相關(guān)的對象的API,并且包裝了通用的servlet相關(guān)功能的方法。session表達(dá)一個請求的javax.servlet.http.HttpSession對象。Session可以存貯用戶的狀態(tài)信息applicaton表達(dá)一個javax.servle.ServletContext對象。這有助于查找有關(guān)servlet引擎和servlet環(huán)境的信息config表達(dá)一個javax.servlet.ServletConfig對象。該對象用于存取servlet實例的初始化參數(shù)。page表達(dá)從該頁面產(chǎn)生的一個servlet實例。線程的基本概念、線程的基本狀態(tài)以及狀態(tài)之間的關(guān)系:線程指在程序執(zhí)行過程中,可以執(zhí)行程序代碼的一個執(zhí)行單位,每個程序至少都有一個線程,也就是程序自身。Java中的線程有四種狀態(tài)分別是:運營、就緒、掛起、結(jié)束。JSP的常用指令:<%@pagelanguage=”java”contenType=”text/html;charset=gb2312”session=”true”buffer=”64kb”autoFlush=”true”isThreadSafe=”true”info=”text”errorPage=”error.jsp”isErrorPage=”true”isELIgnored=”true”pageEncoding=”gb2312”import=”java.sql.*”%>isErrorPage(是否能使用Exception對象),isELIgnored(是否忽略表達(dá)式)<%@includefile=”filename”%><%@taglibprefix=”c”uri=”http://……”%>四種會話跟蹤技術(shù):cookie,url重寫,session,隱藏域。簡述邏輯操作(&,|,^)與條件操作(&&,||)的區(qū)別:區(qū)別重要答兩點:a.條件操作只能操作布爾型的,而邏輯操作不僅可以操作布爾型,并且可以操作數(shù)值型b.邏輯操作不會產(chǎn)生短路。Request對象的重要方法:setAttribute(Stringname,Object):設(shè)立名字為name的request的參數(shù)值getAttribute(Stringname):返回由name指定的屬性值getAttributeNames():返回request對象所有屬性的名字集合,結(jié)果是一個枚舉的實例getCookies():返回客戶端的所有Cookie對象,結(jié)果是一個Cookie數(shù)組getCharacterEncoding():返回請求中的字符編碼方式getContentLength():返回請求的Body的長度getHeader(Stringname):獲得HTTP協(xié)議定義的文獻(xiàn)頭信息getHeaders(Stringname):返回指定名字的requestHeader的所有值,結(jié)果是一個枚舉的實例getHeaderNames():返回所以requestHeader的名字,結(jié)果是一個枚舉的實例getInputStream():返回請求的輸入流,用于獲得請求中的數(shù)據(jù)getMethod():獲得客戶端向服務(wù)器端傳送數(shù)據(jù)的方法getParameter(Stringname):獲得客戶端傳送給服務(wù)器端的由name指定的參數(shù)值getParameterNames():獲得客戶端傳送給服務(wù)器端的所有參數(shù)的名字,結(jié)果是一個枚舉的實例getParameterValues(Stringname):獲得由name指定的參數(shù)的所有值getProtocol():獲取客戶端向服務(wù)器端傳送數(shù)據(jù)所依據(jù)的協(xié)議名稱getQueryString():獲得查詢字符串getRequestURI():獲取發(fā)出請求字符串的客戶端地址getRemoteAddr():獲取客戶端的IP地址getRemoteHost():獲取客戶端的名字getSession([Booleancreate]):返回和請求相關(guān)SessiongetServerName():獲取服務(wù)器的名字getServletPath():獲取客戶端所請求的腳本文獻(xiàn)的途徑getServerPort():獲取服務(wù)器的端標(biāo)語removeAttribute(Stringname):刪除請求中的一個屬性J2EE是技術(shù)還是平臺還是框架:J2EE自身是一個標(biāo)準(zhǔn),一個為公司分布式應(yīng)用的開發(fā)提供的標(biāo)準(zhǔn)平臺。J2EE也是一個框架,涉及JDBC、JNDI、RMI、JMS、EJB、JTA等技術(shù)。編寫java文獻(xiàn)的注意事項:在記事本中編寫java文獻(xiàn),在保存時一定要把文獻(xiàn)名和擴展名用雙引號括起來,否則將默認(rèn)保存為文本文獻(xiàn),假如要保存的java文獻(xiàn)名為Program1.java,則在保存時在文獻(xiàn)名文本框中一定要輸入”Program1.java”。如何編譯java程序:單擊開始|運營命令,在命令行上輸入cmd,按回車鍵(在window98中輸入command,按回車鍵),即可打開一個命令窗口,將目錄轉(zhuǎn)換到編寫java源程序所在的目錄,輸入javacfilename.java如何執(zhí)行java程序:同樣在命令窗口中輸入javafilename。簡述synchronized和java.util.concurrent.locks.Lock的異同:重要相同點:Lock能完畢synchronized所實現(xiàn)的所有功能重要不同點:Lock有比synchronized更精確的線程語義和更好的性能。synchronized會自動釋放鎖,而Lock一定規(guī)定程序員手工釋放,并且必須在finally從句中釋放。EJB的角色和三個對象:一個完整的基于EJB的分布式計算結(jié)構(gòu)由六個角色組成,這六個角色可以由不同的開發(fā)商提供,每個角色所作的工作必須遵循Sun公司提供的EJB規(guī)范,以保證彼此之間的兼容性。這六個角色分別是EJB組件開發(fā)者(EnterpriseBeanProvider)、應(yīng)用組合者(ApplicationAssembler)、部署者(Deployer)、EJB服務(wù)器提供者(EJBServerProvider)、EJB容器提供者(EJBContainerProvider)、系統(tǒng)管理員(SystemAdministrator)三個對象是Remote(Local)接口、Home(LocalHome)接口,Bean類EJB容器提供的服務(wù):重要提供生命周期管理、代碼產(chǎn)生、連續(xù)性管理、安全、事務(wù)管理、鎖和并發(fā)行管理等服務(wù)。EJB規(guī)范規(guī)定EJB中嚴(yán)禁的操作有哪些:1.?不能操作線程和線程API(線程API指非線程對象的方法如notify,wait等),2. 不能操作awt,3. 不能實現(xiàn)服務(wù)器功能4. 不能對靜態(tài)屬性存取,5. 不能使用IO操作直接存取文獻(xiàn)系統(tǒng),6.?不能加載本地庫.,7.?不能將this作為變量和返回,8. 不能循環(huán)調(diào)用。remote接口和home接口重要作用:remote接口定義了業(yè)務(wù)方法,用于EJB客戶端調(diào)用業(yè)務(wù)方法。home接口是EJB工廠用于創(chuàng)建和移除查找EJB實例bean實例的生命周期對于:StatelessSessionBean、EntityBean、MessageDrivenBean一般存在緩沖池管理,而對于EntityBean和StatefullSessionBean存在Cache管理,通常包含創(chuàng)建實例,設(shè)立上下文、創(chuàng)建EJBObject(create)、業(yè)務(wù)方法調(diào)用、remove等過程,對于存在緩沖池管理的Bean,在creat(yī)e之后實例并不從內(nèi)存清除,而是采用緩沖池調(diào)度機制不斷重用實例,而對于存在Cache管理的Bean則通過激活和去激活機制保持Bean的狀態(tài)并限制內(nèi)存中實例數(shù)量。EJB的激活機制:以StatefulSessionBean為例:其Cache大小決定了內(nèi)存中可以同時存在的Bean實例的數(shù)量,根據(jù)MRU或NRU算法,實例在激活和去激活狀態(tài)之間遷移,激活機制是當(dāng)客戶端調(diào)用某個EJB實例業(yè)務(wù)方法時,假如相應(yīng)EJBObject發(fā)現(xiàn)自己沒有綁定相應(yīng)的Bean實例則從其去激活Bean存儲中(通過串行化機制存儲實例)回復(fù)(激活)此實例。狀態(tài)變遷前會調(diào)用相應(yīng)的ejbActive和ejbPassivate方法。EJB的幾種類型:會話(Session)Bean,實體(Entity)Bean消息驅(qū)動的(MessageDriven)Bean;會話Bean又可分為有狀態(tài)(Stateful)和無狀態(tài)(Stat(yī)eless)兩種;實體Bean可分為Bean管理的連續(xù)性(BMP)和容器管理的連續(xù)性(CMP)兩種如何給weblogic指定大小的內(nèi)存:在啟動Weblogic的腳本中(位于所在Domian相應(yīng)服務(wù)器目錄下的startServerName),增長setMEM_ARGS=-Xms32m-Xmx200m,可以調(diào)整最小內(nèi)存為32M,最大200M如何設(shè)定的weblogic的熱啟動模式(開發(fā)模式)與產(chǎn)品發(fā)布模式:可以在管理控制臺中修改相應(yīng)服務(wù)器的啟動模式為開發(fā)或產(chǎn)品模式之一?;蛘咝薷姆?wù)的啟動文獻(xiàn)或者commenv文獻(xiàn),增長setPRODUCTION_M(jìn)ODE=true。如何啟動時不需輸入用戶名與密碼:修改服務(wù)啟動文獻(xiàn),增長WLS_USER和WLS_PW項。也可以在boot.properties文獻(xiàn)中增長加密過的用戶名和密碼.在weblogic管理控制臺中對一個應(yīng)用域(或者說是一個網(wǎng)站,Domain)進(jìn)行jms及ejb或連接池等相關(guān)信息進(jìn)行配置后,實際保存在什么文獻(xiàn)中?保存在此Domain的config.xml文獻(xiàn)中,它是服務(wù)器的核心配置文獻(xiàn)。說說weblogic中一個Domain的缺省目錄結(jié)構(gòu)?比如要將一個簡樸的helloWorld.jsp放入何目錄下,然的在瀏覽器上就可打入http://主機:端標(biāo)語//helloword.jsp就可以看到運營結(jié)果了?又比如這其中用到了一個自己寫的javaBean該如何辦:Domain目錄\服務(wù)器目錄\applicat(yī)ions,將應(yīng)用目錄放在此目錄下將可以作為應(yīng)用訪問,假如是Web應(yīng)用,應(yīng)用目錄需要滿足Web應(yīng)用目錄規(guī)定,jsp文獻(xiàn)可以直接放在應(yīng)用目錄中,Javabean需要放在應(yīng)用目錄的WEB-INF目錄的classes目錄中,設(shè)立服務(wù)器的缺省應(yīng)用將可以實現(xiàn)在瀏覽器上無需輸入應(yīng)用名。在weblogic中發(fā)布ejb需涉及到哪些配置文獻(xiàn):不同類型的EJB涉及的配置文獻(xiàn)不同,都涉及到的配置文獻(xiàn)涉及ejb-jar.xml,weblogic-ejb-jar.xmlCMP實體Bean一般還需要weblogic-cmp-rdbms-jar.xml如何在weblogic中進(jìn)行ssl配置與客戶端的認(rèn)證配置或說說j2ee(標(biāo)準(zhǔn))進(jìn)行ssl的配置:缺省安裝中使用DemoIdentity.jks和DemoTrust.jksKeyStore實現(xiàn)SSL,需要配置服務(wù)器使用EnableSSL,配置其端口,在產(chǎn)品模式下需要從CA獲取私有密鑰和數(shù)字證書,創(chuàng)建identity和trustkeystore,裝載獲得的密鑰和數(shù)字證書??梢耘渲么薙SL連接是單向還是雙向的。如何查看在weblogic中已經(jīng)發(fā)布的EJB:可以使用管理控制臺,在它的Deployment中可以查看所有已發(fā)布的EJBCORBA是什么?用途是什么:CORBA標(biāo)準(zhǔn)是公共對象請求代理結(jié)構(gòu)(CommonObjectRequestBrokerArchitecture),由對象管理組織(ObjectManagementGroup,縮寫為OMG)標(biāo)準(zhǔn)化。它的組成是接口定義語言(IDL),語言綁定(binding:也譯為聯(lián)編)和允許應(yīng)用程序間互操作的協(xié)議。其目的為:用不同的程序設(shè)計語言書寫在不同的進(jìn)程中運營,為不同的操作系統(tǒng)開發(fā)。說說你所熟悉或聽說過的j2ee中的幾種常用模式?及對設(shè)計模式的一些見解:SessionFacadePat(yī)tern:使用SessionBean訪問EntityBean;MessageFacadePattern:實現(xiàn)異步調(diào)用;EJBCommandPattern:使用CommandJavaBeans取代SessionBean,實現(xiàn)輕量級訪問;Dat(yī)aTransferObjectFactory:通過DTOFactory簡化EntityBean數(shù)據(jù)提供特性;GenericAttributeAccess:通過AttibuteAccess接口簡化EntityBean數(shù)據(jù)提供特性;BusinessInterface:通過遠(yuǎn)程(本地)接口和Bean類實現(xiàn)相同接口規(guī)范業(yè)務(wù)邏輯一致性;EJB架構(gòu)的設(shè)計好壞將直接影響系統(tǒng)的性能、可擴展性、可維護(hù)性、組件可重用性及開發(fā)效率。項目越復(fù)雜,項目隊伍越龐大則越能體現(xiàn)良好設(shè)計的重要性。說說在weblogic中開發(fā)消息Bean時的persistent與non-persistent的差別:persistent方式的MDB可以保證消息傳遞的可靠性,也就是假如EJB容器出現(xiàn)問題而JMS服務(wù)器仍然會將消息在此MDB可用的時候發(fā)送過來,而non-persistent方式的消息將被丟棄。常用的設(shè)計模式?說明工廠模式:Java中的23種設(shè)計模式:Factory(工廠模式),Builder(建造模式),FactoryMethod(工廠方法模式),Prototype(原始模型模式),Singleton(單例模式),Facade(門面模式),Adapter(適配器模式),Bridge(橋梁模式),Composite(合成模式),Decorator(裝飾模式),Flyweight(享元模式),Proxy(代理模式),Command(命令模式),Interpreter(解釋器模式),Visitor(訪問者模式),Iterator(迭代子模式),Mediator(調(diào)停者模式),Memento(備忘錄模式),Observer(觀測者模式),State(狀態(tài)模式),Strategy(策略模式),TemplateMethod(模板方法模式),ChainOfResponsibleity(責(zé)任鏈模式)。工廠模式:工廠模式是一種經(jīng)常被使用到的模式,根據(jù)工廠模式實現(xiàn)的類可以根據(jù)提供的數(shù)據(jù)生成一組類中某一個類的實例,通常這一組類有一個公共的抽象父類并且實現(xiàn)了相同的方法,但是這些方法針對不同的數(shù)據(jù)進(jìn)行了不同的操作。一方面需要定義一個基類,該類的子類通過不同的方法實現(xiàn)了基類中的方法。然后需要定義一個工廠類,工廠類可以根據(jù)條件生成不同的子類實例。當(dāng)?shù)玫阶宇惖膶嵗?開發(fā)人員可以調(diào)用基類中的方法而不必考慮到底返回的是哪一個子類的實例。請對以下在J2EE中常用的名詞進(jìn)行解釋(或簡樸描述):web容器:給處在其中的應(yīng)用程序組件(JSP,SERVLET)提供一個環(huán)境,使JSP,SERVLET直接跟容器中的環(huán)境變量接口交互,不必關(guān)注其它系統(tǒng)問題。重要有WEB服務(wù)器來實現(xiàn)。例如:TOMCAT,WEBLOGIC,WEBSPHERE等。該容器提供的接口嚴(yán)格遵守J2EE規(guī)范中的WEBAPPLICATION標(biāo)準(zhǔn)。我們把遵守以上標(biāo)準(zhǔn)的WEB服務(wù)器就叫做J2EE中的WEB容器。EJB容器:Enterprisejavabean容器。更具有行業(yè)領(lǐng)域特色。他提供應(yīng)運營在其中的組件EJB各種管理功能。只要滿足J2EE規(guī)范的EJB放入該容器,立即就會被容器進(jìn)行高效率的管理。并且可以通過現(xiàn)成的接口來獲得系統(tǒng)級別的服務(wù)。例如郵件服務(wù)、事務(wù)管理。JNDI:(JavaNaming&DirectoryInterface)JAVA命名目錄服務(wù)。重要提供的功能是:提供一個目錄系統(tǒng),讓其它各地的應(yīng)用程序在其上面留下自己的索引,從而滿足快速查找和定位分布式應(yīng)用程序的功能。JMS:(JavaMessageService)JAVA消息服務(wù)。重要實現(xiàn)各個應(yīng)用程序之間的通訊。涉及點對點和廣播。JTA:(JavaTransactionAPI)JAVA事務(wù)服務(wù)。提供各種分布式事務(wù)服務(wù)。應(yīng)用程序只需調(diào)用其提供的接口即可。JAF:(JavaActionFrameWork)JAVA安全認(rèn)證框架。提供一些安全控制方面的框架。讓開發(fā)者通過各種部署和自定義實現(xiàn)自己的個性安全控制策略。RMI/IIOP:(RemoteMethodInvocation/internet對象請求中介協(xié)議)他們重要用于通過遠(yuǎn)程調(diào)用服務(wù)。例如,遠(yuǎn)程有一臺計算機上運營一個程序,它提供股票分析服務(wù),我們可以在本地計算機上實現(xiàn)對其直接調(diào)用。當(dāng)然這是要通過一定的規(guī)范才干在異構(gòu)的系統(tǒng)之間進(jìn)行通信。RMI是JAVA特有的。一個“.java”源文獻(xiàn)中是否可以涉及多個類(不是內(nèi)部類)?有什么限制:可以。必須只有一個類名與文獻(xiàn)名相同。MVC的各個部分都有那些技術(shù)來實現(xiàn)?如何實現(xiàn):MVC是Model-View-Controller的簡寫。"Model"代表的是應(yīng)用的業(yè)務(wù)邏輯(通過JavaBean,EJB組件實現(xiàn)),"View"是應(yīng)用的表達(dá)面(由JSP頁面產(chǎn)生),"Controller"是提供應(yīng)用的解決過程控制(一般是一個Servlet),通過這種設(shè)計模型把應(yīng)用邏輯,解決過程和顯示邏輯提成不同的組件實現(xiàn)。這些組件可以進(jìn)行交互和重用。java中有幾種方法可以實現(xiàn)一個線程?用什么關(guān)鍵字修飾同步方法?stop()和suspend()方法為什么不推薦使用:有兩種實現(xiàn)方法,分別是繼承Thread類與實現(xiàn)Runnable接口用synchronized關(guān)鍵字修飾同步方法反對使用stop(),是由于它不安全。它會解除由線程獲取的所有鎖定,并且假如對象處在一種不連貫狀態(tài),那么其他線程能在那種狀態(tài)下檢查和修改它們。結(jié)果很難檢查出真正的問題所在。suspend()方法容易發(fā)生死鎖。調(diào)用suspend()的時候,目的線程會停下來,但卻仍然持有在這之前獲得的鎖定。此時,其他任何線程都不能訪問鎖定的資源,除非被“掛起”的線程恢復(fù)運營。對任何線程來說,假如它們想恢復(fù)目的線程,同時又試圖使用任何一個鎖定的資源,就會導(dǎo)致死鎖。所以不應(yīng)當(dāng)使用suspend(),而應(yīng)在自己的Thread類中置入一個標(biāo)志,指出線程應(yīng)當(dāng)活動還是掛起。若標(biāo)志指出線程應(yīng)當(dāng)掛起,便用wait()命令進(jìn)入等待狀態(tài)。若

溫馨提示

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

評論

0/150

提交評論