面試題程序員面試122題_第1頁(yè)
面試題程序員面試122題_第2頁(yè)
面試題程序員面試122題_第3頁(yè)
面試題程序員面試122題_第4頁(yè)
面試題程序員面試122題_第5頁(yè)
已閱讀5頁(yè),還剩42頁(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、java 面試題及(基礎(chǔ)題 122 道,代碼題 19 道)java 面試題及(基礎(chǔ)題 122 道,代碼題 19 道)JAVA 相關(guān)基礎(chǔ)知識(shí)1、面向?qū)ο蟮奶卣饔心男┓矫?.抽象:抽象就是忽略一個(gè)主題中與當(dāng)前目標(biāo)無(wú)關(guān)的那些方面,以便更充分地注意與當(dāng)前目標(biāo)有關(guān)的方面。抽象并不打算了解全部問(wèn)題,而只是選擇其中的一部分,暫時(shí)不用部分 細(xì)節(jié)。抽象包括兩個(gè)方面,一是過(guò)程抽象,二是數(shù)據(jù)抽象。2.繼承:繼承是一種聯(lián)結(jié)類的層次模型,并且和鼓勵(lì)類的重用,它提供了一種明確表述共性的方法。對(duì)象的一個(gè)新類可以從現(xiàn)有的類中派生,這個(gè)過(guò)程稱為類繼承。新類繼承了原始類的特性,新類稱為原始類的派生類(子類),而原始類稱為新類的基

2、類(父 類)。派生類可以從它的基類那里繼承方法和實(shí)例變量,并且類可以修改或增加新的 方法使之更適合特殊的需要。3.封裝:封裝是把過(guò)程和數(shù)據(jù)包圍起來(lái),對(duì)數(shù)據(jù)的只能通過(guò)已定義的界面。面向?qū)ο笥?jì)算始于這個(gè)基本概念,即現(xiàn)實(shí)世界可以被描繪成一系列完全自治、封裝的對(duì)象,這些對(duì)象通過(guò)一個(gè)受保護(hù)的接口其他對(duì)象。4. 多態(tài)性:多態(tài)性是指不同類的對(duì)象對(duì)同一消息作出響應(yīng)。多態(tài)性包括參數(shù)化多態(tài)性和包含多態(tài)性。多態(tài)性語(yǔ)言具有靈活、抽象、行為共享、代碼共享的優(yōu)勢(shì),很好的解決了應(yīng)用程序函數(shù)同名問(wèn)題。2、String 是最基本的數(shù)據(jù)類型嗎?基本數(shù)據(jù)類型包括 byte、int、char、long、float、double、bo

3、olean 和 short。java.lang.String 類是 final 類型的,因此不可以繼承這個(gè)類、不能修改這個(gè)類。為了提高效率節(jié)省空間,我們應(yīng)該用 StringBuffer 類3、int 和 Integer 有什么區(qū)別Java 提供兩種不同的類型:類型和原始類型(或內(nèi)置類型)。Int 是 java 的原始數(shù)據(jù)類型,Integer 是 java 為 int 提供的封裝類。Java 為每個(gè)原始類型提供了封裝類。原始類型封裝類booleanBoolean charCharacter byteByte shortShort intInteger longLong floatFloatdou

4、bleDouble類型和原始類型的行為完全不同,并且它們具有不同的語(yǔ)義。類型和原始類型具有不同的特征和用法,它們包括:大小和速度問(wèn)題,這種類型以哪種類型的數(shù)據(jù)結(jié)構(gòu),當(dāng)類型和原始類型用作某個(gè)類的實(shí)例數(shù)據(jù)時(shí)所指定的缺省值。對(duì)象引用實(shí)例變量的缺省值為 null,而原始類型實(shí)例變量的缺省值與它們的類型有關(guān)。4、String 和 StringBuffer 的區(qū)別JAVA 平臺(tái)提供了兩個(gè)類:String 和 StringBuffer,它們可以儲(chǔ)存和操作字符串,即包含多個(gè)字符的字符數(shù)據(jù)。這個(gè) String 類提供了數(shù)值不可改變的字符串。而這個(gè)StringBuffer 類提供的字符串進(jìn)行修改。當(dāng)你知道字符數(shù)據(jù)

5、要改變的時(shí)候你就可以使用StringBuffer。典型地,你可以使用 StringBuffers 來(lái)動(dòng)態(tài)構(gòu)造字符數(shù)據(jù)。5、運(yùn)行時(shí)異常與一般異常有何異同?異常表示程序運(yùn)行過(guò)程中可能出現(xiàn)的狀態(tài),運(yùn)行時(shí)異常表示虛擬機(jī)的通常操作中可能遇到的異常,是一種常見(jiàn)運(yùn)行錯(cuò)誤。java 編譯器要求方法必須拋出可能發(fā)生的非運(yùn)行時(shí)異常,但是并不要求必須拋出未獲的運(yùn)行時(shí)異常。6、說(shuō)出 Servlet 的生命周期,并說(shuō)出 Servlet 和 CGI 的區(qū)別。Servlet 被服務(wù)器實(shí)例化后,容器運(yùn)行其 init 方法,請(qǐng)求到達(dá)時(shí)運(yùn)行其 service 方法,service 方法自動(dòng)派遣運(yùn)行與請(qǐng)求對(duì)應(yīng)的 do方法(doGe

6、t,doPost)等,當(dāng)服務(wù)器決定將實(shí)例銷(xiāo)毀的時(shí)候調(diào)用其 destroy 方法。與 cgi 的區(qū)別在于 servlet 處于服務(wù)器進(jìn)程中,它通過(guò)多線程方式運(yùn)行其 service 方法,一個(gè)實(shí)例可以服務(wù)于多個(gè)請(qǐng)求,并且其實(shí)例一般銷(xiāo)毀,而 CGI 對(duì)每個(gè)請(qǐng)求都產(chǎn)生新的進(jìn)程,服務(wù)完成后就銷(xiāo)毀,所以效率上低于 servlet。7、說(shuō)出 ArrayList,Vector, LinkedList 的性能和特性ArrayList 和 Vector 都是使用數(shù)組方式數(shù)據(jù),此數(shù)組元素?cái)?shù)大于實(shí)際的數(shù)據(jù)以便增加和元素,它們都直接按序號(hào)索引元素,但是元素要涉及數(shù)組元素移動(dòng)等內(nèi)存操作,所以索引數(shù)據(jù)快而數(shù)據(jù)慢,Vecto

7、r 由于使用了 synchronized 方法(線程安全),通常性能上較 ArrayList 差,而 LinkedList 使向鏈表實(shí)現(xiàn),按序號(hào)索引數(shù)據(jù)需要進(jìn)行前向或后向遍歷,但是數(shù)據(jù)時(shí)只需要本項(xiàng)的前后項(xiàng)即可,所以速度較快。8、EJB 是基于哪些技術(shù)實(shí)現(xiàn)的?并說(shuō)出 SessionBean 和 EntityBean 的區(qū)別,StatefulBean 和 StatelessBean 的區(qū)別。EJB 包括 Session Bean、Entity Bean、Message Driven Bean,基于 JNDI、RMI、JAT等技術(shù)實(shí)現(xiàn)。SessionBean 在 J2EE 應(yīng)用程序中被用來(lái)完成一些服

8、務(wù)器端的業(yè)務(wù)操作,例如庫(kù)、調(diào)用其他 EJB 組件。EntityBean 被用來(lái)代表應(yīng)用系統(tǒng)中用到的數(shù)據(jù)。數(shù)據(jù)對(duì)于客戶機(jī),SessionBean 是一種非持久性對(duì)象,它實(shí)現(xiàn)某些在服務(wù)器上運(yùn)行的業(yè)務(wù)邏輯。對(duì)于客戶機(jī),EntityBean 是一種持久性對(duì)象,它代表一個(gè)在持久性體的對(duì)象視圖,或是一個(gè)由現(xiàn)有企業(yè)應(yīng)用程序?qū)崿F(xiàn)的實(shí)體。器中的實(shí)Session Bean 還可以再細(xì)分為 Stateful Session Bean 與 Stateless Session Bean ,這兩種的 Session Bean 都可以將系統(tǒng)邏輯放在 method 之中執(zhí)行,不同的是 StatefulSession Bean

9、 可以呼叫者的狀態(tài),因此通常來(lái)說(shuō),一個(gè)使用者會(huì)有一個(gè)相對(duì)應(yīng)的Stateful Session Bean 的實(shí)體。Stateless Session Bean 雖然也是邏輯組件,但是他卻不負(fù)責(zé)使用者狀態(tài),也就是說(shuō)當(dāng)使用者呼叫 Stateless Session Bean 的時(shí)候,EJBContainer 并找尋特定的 Stateless Session Bean 的實(shí)體來(lái)執(zhí)行這個(gè) method。換言之,很可能數(shù)個(gè)使用者在執(zhí)行某個(gè) Stateless Session Bean 的 methods 時(shí),會(huì)是同一個(gè) Bean 的 Instance 在執(zhí)行。從內(nèi)存方面來(lái)看, Stateful Sessi

10、on Bean 與 Stateless Session Bean 比較, Stateful Session Bean 會(huì)消耗 J2EE Server 較多的內(nèi)存,然而Stateful Session Bean 的優(yōu)勢(shì)卻在于他可以維持使用者的狀態(tài)。9、Collection 和 Collections 的區(qū)別。Collection 是集合類的接口,繼承與他的接口主要有 Set 和 List.Collections 是集合類的一個(gè)幫助類,他提供一系列靜態(tài)方法實(shí)現(xiàn)對(duì)各種集合的搜索、排序、線程安全化等操作。10、&和&&的區(qū)別。&是位運(yùn)算符,表示按位與運(yùn)算,&&a

11、mp;是邏輯運(yùn)算符,表示邏輯與(and)。11、HashMap 和 Hashtable 的區(qū)別。HashMap 是 Hashtable 的輕量級(jí)實(shí)現(xiàn)(非線程安全的實(shí)現(xiàn)),他們都完成了 Map 接口,主要區(qū)別在于 HashMap能高于 Hashtable??眨╪ull)鍵值(key),由于非線程安全,效率上可HashMap將 null 作為一個(gè) entry 的 key 或者 value,而 Hashtable 不。HashMap 把 Hashtable 的 contains 方法去掉了,改成 containsvalue 和 containsKey。因?yàn)?contains 方法容易讓人引起誤解。H

12、ashtable 繼承自 Dictionary 類,而 HashMap 是 Java1.2 引進(jìn)的 Map interface 的一個(gè)實(shí)現(xiàn)。最大的不同是,Hashtable 的方法是 Synchronize 的,而 HashMap 不是,在多個(gè)線程Hashtable 時(shí),不需要同步。為它的方法實(shí)現(xiàn)同步,而 HashMap 就必須為之提供外Hashtable 和 HashMap 采用的 hash/rehash 算法都大概一樣,所以性能差異。有很大的12、final, finally, finalize 的區(qū)別。final 用于承。屬性,方法和類,分別表示屬性不可變,方法不可覆蓋,類不可繼fina

13、lly 是異常處理語(yǔ)句結(jié)構(gòu)的一部分,表示總是執(zhí)行。finalize 是 Object 類的一個(gè)方法,在收集器執(zhí)行的時(shí)候會(huì)調(diào)用被回收對(duì)象的此方法,可以覆蓋此方法提供收集時(shí)的其他回收,例如關(guān)閉文件等。13、sleep() 和 wait() 有什么區(qū)別?sleep 是線程類(Thread)的方法,導(dǎo)致此線程暫停執(zhí)行指定時(shí)間,給執(zhí)行機(jī)會(huì)給其他線程,但是狀態(tài)依然保持,到時(shí)后會(huì)自動(dòng)恢復(fù)。調(diào)用 sleep對(duì)象鎖。wait 是 Object 類的方法,對(duì)此對(duì)象調(diào)用 wait 方法導(dǎo)致本線程放棄對(duì)象鎖,進(jìn)入等待此對(duì)象的等待鎖定池,只有此對(duì)象發(fā)出 notify 方法(或 notifyAll)后本線程才進(jìn)入對(duì)象鎖定

14、池準(zhǔn)備獲得對(duì)象鎖進(jìn)入運(yùn)行狀態(tài)。14、Overload 和 Override 的區(qū)別。Overloaded 的方法是否可以改變返回值的類型?方法的重寫(xiě) Overriding 和重載 Overloading 是 Java 多態(tài)性的不同表現(xiàn)。重寫(xiě)Overriding 是父類與子類之間多態(tài)性的一種表現(xiàn),重載 Overloading 是一個(gè)類中多態(tài)性的一種表現(xiàn)。如果在子類中定義某方法與其父類有相同的名稱和參數(shù),我們說(shuō)該方法被重寫(xiě) (Overriding)。子類的對(duì)象使用這個(gè)方法時(shí),將調(diào)用子類中的定義,對(duì)它而言,父類中的定義如同被“”了。如果在一個(gè)類中定義了多個(gè)同名的方法,它們或有不同的參數(shù)個(gè)數(shù)或有不同的

15、參數(shù)類型,則稱為方法的重載(Overloading)。Overloaded的方法是可以改變返回值的類型。15、error 和 exception 有什么區(qū)別?error 表示恢復(fù)不是不可能但很能指望程序能處理這樣的情況。的情況下的一種嚴(yán)重問(wèn)題。比如說(shuō)內(nèi)存溢出。不可exception 表示一種設(shè)計(jì)或?qū)崿F(xiàn)問(wèn)題。也就是說(shuō),它表示如果程序運(yùn)行正常,從生的情況。發(fā)16、同步和異步有何異同,在什么情況下分別使用他們?舉例說(shuō)明。如果數(shù)據(jù)將程間共享。例如正在寫(xiě)的數(shù)據(jù)以后可能被另一個(gè)線程讀到,或者正在讀的數(shù)據(jù)可能已經(jīng)被另一個(gè)線程寫(xiě)過(guò)了,那么這些數(shù)據(jù)就是共享數(shù)據(jù),必須進(jìn)行同步存取。當(dāng)應(yīng)用程序在對(duì)象上調(diào)用了一個(gè)需要

16、花費(fèi)很長(zhǎng)時(shí)間來(lái)執(zhí)行的方法,并且不希望讓程序等待方法的返回時(shí),就應(yīng)該使用異步編程,在很多情況下采用異步途徑往往更有效 率。17、abstract class 和 interface 有什么區(qū)別?方法的存在而不去實(shí)現(xiàn)它的類被叫做抽象類(abstract class),它用于要?jiǎng)?chuàng)建一現(xiàn)某些基本行為的類,并為該類方法,但不能在該類中實(shí)現(xiàn)該類的情況。不能創(chuàng)建 abstract 類的實(shí)例。然而可以創(chuàng)建一個(gè)變量,其類型是一個(gè)抽象類,并讓它指向具體子類的一個(gè)實(shí)例。不能有抽象構(gòu)造函數(shù)或抽象靜態(tài)方法。Abstract 類的子類為它們父類中的所有抽象方法提供實(shí)現(xiàn),否則它們也是抽象類為。取而代之,在子類中 實(shí)現(xiàn)該方法

17、。知道其行為的其它類可以在類中實(shí)現(xiàn)這些方法。接口(interface)是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過(guò)實(shí)現(xiàn)這樣的接口而獲得。接口中的所有方法都是抽象的,沒(méi)有一個(gè)有程序體。接口 只可以定義 static final 成員變量。接口的實(shí)現(xiàn)與子類相似,除了該實(shí)現(xiàn)類不能從接口定義中繼承行為。當(dāng)類實(shí)現(xiàn)特殊接口時(shí),它定義(即將程序體給予)所有這種接口的 方法。然后,它可以在實(shí)現(xiàn)了該接口的類的任何對(duì)象上調(diào)用接口的方法。由于有抽象類,它使用接口名作為變量的類型。通常的動(dòng)態(tài)聯(lián)編將生效??梢赞D(zhuǎn)換到接口類型或從接口類型轉(zhuǎn)換,instanceof 運(yùn)算符可以用來(lái)決定某對(duì)象的類是否實(shí)現(xiàn)了接口

18、。18、heap 和 stack 有什么區(qū)別。棧是一種線形集合,其添加和刪除元素的操作應(yīng)在同一段完成。棧按照后進(jìn)先出的方式進(jìn)行處理。堆是棧的一個(gè)組成元素19、forward 和 redirect 的區(qū)別forward 是服務(wù)器請(qǐng)求,服務(wù)器直接目標(biāo)地址的 URL,把那個(gè) URL 的響應(yīng)內(nèi)容過(guò)來(lái),然后把這些內(nèi)容再發(fā)給瀏覽器,瀏覽器根本不知道服務(wù)器的內(nèi)容是從哪兒來(lái)的,所以它的地址欄中還是原來(lái)的地址。redirect 就是服務(wù)端根據(jù)邏輯,一個(gè)狀態(tài)碼,告訴瀏覽器重新去請(qǐng)求那個(gè)地址,一般來(lái)說(shuō)瀏覽器會(huì)用剛才請(qǐng)求的所有參數(shù)重新請(qǐng)求,所以 session,request 參數(shù)都可以獲取。20、EJB 與 JAV

19、A BEAN 的區(qū)別?Java Bean 是可復(fù)用的組件,對(duì) Java Bean 并沒(méi)有嚴(yán)格的規(guī)范,理論上講,任何一個(gè)Java 類都可以是一個(gè) Bean。但通常情況下,由于 Java Bean 是被容器所創(chuàng)建(如Tomcat)的,所以 Java Bean 應(yīng)具有一個(gè)無(wú)參的構(gòu)造器,另外,通常 Java Bean 還要實(shí)現(xiàn) Serializable 接口用于實(shí)現(xiàn) Bean 的持久性。Java Bean 實(shí)際上相當(dāng)于微軟 COM 模型中的本地進(jìn)程內(nèi) COM 組件,它是不能被跨進(jìn)程的。Enterprise Java Bean 相當(dāng)于 DCOM,即分布式組件。它是基于 Java 的方法調(diào)用(RMI)技術(shù)

20、的,所以 EJB可以被(跨進(jìn)程、跨計(jì)算機(jī))。但 EJB 必須被布署在諸如 Webspere、WebLogic 這樣的容器中,EJB 客戶從不直接真正的 EJB 組件,而是通過(guò)其容器訪問(wèn)。EJB 容器是 EJB 組件的真正的 EJB 組件。,EJB 組件由容器所創(chuàng)建和管理??蛻敉ㄟ^(guò)容器來(lái)21、Static Nested Class 和 Inner Class 的不同。Static Nested Class 是被為靜態(tài)(static)的內(nèi)部類,它可以不依賴于外部類實(shí)例被實(shí)例化。而通常的內(nèi)部類需要在外部類實(shí)例化后才能實(shí)例化。22、JSP 中動(dòng)態(tài) INCLUDE 與靜態(tài) INCLUDE 的區(qū)別?動(dòng)態(tài)

21、INCLUDE 用 jsp:include 動(dòng)作實(shí)現(xiàn) <jsp:include page="included.jsp" flush="true"/>它總是會(huì)檢查所含文件中的變化,適合用于包含動(dòng)態(tài)頁(yè)面,并且可以帶參數(shù)。靜態(tài) INCLUDE 用 include 偽碼實(shí)現(xiàn),定<% include file="included.htm" %>檢查所含文件的變化,適用于包含靜態(tài)頁(yè)面23、什么時(shí)候用 assert。assertion(斷言)在軟件開(kāi)發(fā)中是一種常用的調(diào)試方式,很多開(kāi)發(fā)語(yǔ)言中都支持這種機(jī)制。在實(shí)現(xiàn)中,asser

22、tion 就是在程序中的一條語(yǔ)句,它對(duì)一個(gè) boolean 表達(dá)式進(jìn)行檢查,一個(gè)正確程序必須保證這個(gè) boolean 表達(dá)式的值為 true;如果該值為 false,說(shuō)明程序已經(jīng)處于不正確的狀態(tài)下,系統(tǒng)將給出警告或。一般來(lái)說(shuō),assertion 用于保證程序最基本、關(guān)鍵的正確性。assertion 檢查通常在開(kāi)發(fā)和測(cè)試時(shí)開(kāi)啟。為了提高性能,在軟件發(fā)布后,assertion 檢查通常是關(guān)閉的。24、GC 是什么? 為什么要有 GC?GC 是收集的意思(Gabage Collection),內(nèi)存處理是編程容易出現(xiàn)問(wèn)題的,Java 提供的 GC地方,忘記或者錯(cuò)誤的內(nèi)存回收會(huì)導(dǎo)致程序或系統(tǒng)的不穩(wěn)定甚至

23、功能可以自動(dòng)監(jiān)測(cè)對(duì)象是否超過(guò)作用域從而達(dá)到自動(dòng)回收內(nèi)存的目的,Java 語(yǔ)言沒(méi)有提供已分配內(nèi)存的顯示操作方法。25、short s1 = 1; s1 = s1 + 1;有什么錯(cuò)? short s1 = 1; s1 += 1;有什么錯(cuò)?short s1 = 1; s1 = s1 + 1; (s1+1 運(yùn)算結(jié)果是 int 型,需要強(qiáng)制轉(zhuǎn)換類型)short s1 = 1; s1 += 1;(可以正確編譯)26、Math.round(11.5)等於多少? Math.round(-11.5)等於多少?Math.round(11.5)=12Math.round(-11.5)=-11round 方法返回與參

24、數(shù)最接近的長(zhǎng)整數(shù),參數(shù)加 1/2 后求其 floor.27、String s = new String("xyz");創(chuàng)建了幾個(gè) String Object?兩個(gè)28、設(shè)計(jì) 4 個(gè)線程,其中兩個(gè)線程每次對(duì) j 增加 1,另外兩個(gè)線程對(duì) j 每次減少 1。寫(xiě)出程序。以下程序使用內(nèi)部類實(shí)現(xiàn)線程,對(duì) j 增減的時(shí)候沒(méi)有考慮順序問(wèn)題。public class ThreadTest1 private int j;public static void main(String args) ThreadTest1 tt=new ThreadTest1(); Inc inc=tt.new I

25、nc();Dec dec=tt.new Dec(); for(int i=0;i<2;i+) Thread t=new Thread(inc); t.start();t=new Thread(dec); t.start();private synchronized void inc() j+;System.out.println(Thread.currentThread().getName()+"-inc:"+j);private synchronized void dec() j-;System.out.println(Thread.currentThread().

26、getName()+"-dec:"+j);class Inc implements Runnable public void run()for(int i=0;i<100;i+) inc();class Dec implements Runnable public void run()for(int i=0;i<100;i+) dec();29、Java 有沒(méi)有 goto?java 中的保留字,現(xiàn)在沒(méi)有在 java 中使用。30、啟動(dòng)一個(gè)線程是用 run()還是 start()?啟動(dòng)一個(gè)線程是調(diào)用 start()方法,使線程所代表的虛擬處理機(jī)處于可運(yùn)行狀態(tài),這意

27、味著它可以由 JVM 調(diào)度并執(zhí)行。這并不意味著線程就會(huì)立即運(yùn)行。run()方法可以產(chǎn)生必須的標(biāo)志來(lái)停止一個(gè)線程。31、EJB 包括(SessionBean,EntityBean)說(shuō)出他們的生命周期,及如何管理事務(wù)的?SessionBean:Stateless Session Bean 的生命周期是由容器決定的,當(dāng)客戶機(jī)發(fā)出請(qǐng)求要建立一個(gè) Bean 的實(shí)例時(shí),EJB 容器不一定要?jiǎng)?chuàng)建一個(gè)新的 Bean 的實(shí)例供客戶機(jī)調(diào)用,而是隨便找一個(gè)現(xiàn)有的實(shí)例提供給客戶機(jī)。當(dāng)客戶機(jī)第一次調(diào)用一個(gè) Stateful Session Bean 時(shí),容器必須立即在服務(wù)器中創(chuàng)建一個(gè)新的 Bean 實(shí)例,并關(guān)聯(lián)到客戶機(jī)

28、上,以后此客戶機(jī)調(diào)用 Stateful Session Bean 的方法時(shí)容器會(huì)把調(diào)用分派到與此客戶機(jī)相關(guān)聯(lián)的 Bean 實(shí)例。EntityBean:Entity Beans 能存活相對(duì)較長(zhǎng)的時(shí)間,并且狀態(tài)是持續(xù)的。只要數(shù)據(jù)庫(kù)中的數(shù)據(jù)存在,Entity beans 就一直存活。而不是按照應(yīng)用程序或者服務(wù)進(jìn)程來(lái)說(shuō)的。即使 EJB 容器了,Entity beans 也是存活的。Entity Beans 生命周期能夠被容器或者Beans管理。EJB 通過(guò)以下技術(shù)管理實(shí)務(wù):對(duì)象管理組織(OMG)的對(duì)象實(shí)務(wù)服務(wù)(OTS),SunMicrosystems 的 Transaction Service(JTS

29、)、Java Transaction API(JTA),開(kāi)發(fā)組(X/Open)的 XA 接口。32、應(yīng)用服務(wù)器有那些?BEA WebLogic Server,IBM WebSphere Application Server,Oracle9i ApplicationServer,jBoss,Tomcat33、給我一個(gè)你最常見(jiàn)到的 runtime exception。ArithmeticException, ArrayStoreException, BufferOverflowException, BufferUnderflowException, CannotRedoException, Can

30、notUndoException, ClassCastException, CMMException, ConcurrentModificationException, DOMException, EmptyStackException, IllegalArgumentException, IllegalMonitorStateException, IllegalPathStateException, IllegalStateException, ImagingOpException, IndexOutOfBoundsException, MissingResourceException, N

31、egativeArraySizeException, NoSuchElementException, NullPointerException, ProfileDataException, ProviderException, RasterFormatException, SecurityException, SystemException, UndeclaredThrowableException, UnmodifiableSetException, UnsupportedOperationException34、接口是否可繼承接口? 抽象類是否可實(shí)現(xiàn)(implements)接口? 抽象類是

32、否可繼承實(shí)體類(concrete class)?接口可以繼承接口。抽象類可以實(shí)現(xiàn)(implements)接口,抽象類是否可繼承實(shí)體類,但前提是實(shí)體類必須有明確的構(gòu)造函數(shù)。35、List, Set, Map 是否繼承自 Collection 接口?List,Set 是,Map 不是36、說(shuō)出數(shù)據(jù)連接池的工作機(jī)制是什么?J2EE 服務(wù)器啟動(dòng)時(shí)會(huì)建立一定數(shù)量的池連接,并一直維持不少于此數(shù)目的池連接。客戶端程序需要連接時(shí),池驅(qū)動(dòng)程序會(huì)返回一個(gè)未使用的池連接并將其表記為忙。如果 當(dāng)前沒(méi)有空閑連接,池驅(qū)動(dòng)程序就新建一定數(shù)量的連接,新建連接的數(shù)量有配置參數(shù) 決定。當(dāng)使用的池連接調(diào)用完成后,池驅(qū)動(dòng)程序?qū)⒋诉B接

33、表記為空閑,其他調(diào)用就可 以使用這個(gè)連接。37、abstract 的 method 是否可同時(shí)是 static,是否可同時(shí)是 native,是否可同時(shí)是synchronized?都不能38、數(shù)組有沒(méi)有 length()這個(gè)方法? String 有沒(méi)有 length()這個(gè)方法?數(shù)組沒(méi)有 length()這個(gè)方法,有 length 的屬性。String 有有 length()這個(gè)方法。39、Set 里的元素是不能重復(fù)的,那么用什么方法來(lái)區(qū)分重復(fù)與否呢? 是用=還是equals()? 它們有何區(qū)別?Set 里的元素是不能重復(fù)的,那么用 iterator()方法來(lái)區(qū)分重復(fù)與否。equals()是判讀

34、兩個(gè) Set 是否相等。equals()和=方法決定值是否指向同一對(duì)象 equals()在類中被覆蓋,為的是當(dāng)兩個(gè)分離的對(duì)象的內(nèi)容和類型相配的話,返回真值。40、構(gòu)造器 Constructor 是否可被 override?構(gòu)造器 Constructor 不能被繼承,因此不能重寫(xiě) Overriding,但可以被重載Overloading。41、是否可以繼承 String 類?String 類是 final 類故不可以繼承。42、swtich 是否能作用在 byte 上,是否能作用在 long 上,是否能作用在 String 上?switch(expr1)中,expr1 是一個(gè)整數(shù)表達(dá)式。因此傳遞

35、給 switch 和 case 語(yǔ)句的參數(shù)應(yīng)該是 int、 short、 char 或者 byte。long,string 都不能作用于 swtich。43、try 里有一個(gè) return 語(yǔ)句,那么緊跟在這個(gè) try 后的 finally 里的 code 會(huì)被執(zhí)行,什么時(shí)候被執(zhí)行,在 return 前還是后?會(huì)執(zhí)行,在 return 前執(zhí)行。44、編程題: 用最有效率的方法算出 2 乘以 8 等於幾?2 << 345、兩個(gè)對(duì)象值相同(x.equals(y) = true),但卻可有不同的 hash code,這句話對(duì)不對(duì)?不對(duì),有相同的 hash code。46、當(dāng)一個(gè)對(duì)象被當(dāng)作

36、參數(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)改變的。47、當(dāng)一個(gè)線程進(jìn)入一個(gè)對(duì)象的一個(gè) synchronized 方法后,其它線程是否可進(jìn)入此對(duì)象的其它方法?不能,一個(gè)對(duì)象的一個(gè) synchronized 方法只能由一個(gè)線程。48、編程題: 寫(xiě)一個(gè) Singleton 出來(lái)。Singleton 模式主要作用是保證在 Java 應(yīng)用程序中,一個(gè)類 Class 只有一個(gè)實(shí)例存在。一

37、般 Singleton 模式通常有幾種種形式:第一種形式: 定義一個(gè)類,它的構(gòu)造函數(shù)為 private 的,它有一個(gè) static 的 private 的該類變量,在類初始化時(shí)實(shí)例話,通過(guò)一個(gè) public 的 getInstance 方法獲取對(duì)它的繼而調(diào)用其中的方法。public class Singleton private Singleton(),/在內(nèi)部定義一個(gè)實(shí)例,是不是很奇怪?/注意這是 private 只供內(nèi)部調(diào)用private static Singleton instance = new Singleton();/這里提供了一個(gè)供外部本 class 的靜態(tài)方法,可以直接pub

38、lic static Singleton getInstance() return instance;第二種形式:public class Singleton private static Singleton instance = null;public static synchronized Singleton getInstance() /這個(gè)方法比上面有所改進(jìn),不用每次都進(jìn)行生成對(duì)象,只是第一次/使用時(shí)生成實(shí)例,提高了效率!if (instance=null)instancenew Singleton();return instance;其他形式:定義一個(gè)類,它的構(gòu)造函數(shù)為 privat

39、e 的,所有方法為 static 的。一般認(rèn)為第一種形式要更加安全些49、Java 的接口和 C+的虛類的相同和不同處。由于 Java 不支持多繼承,而有可能某個(gè)類或?qū)ο笠褂梅謩e在幾個(gè)類或?qū)ο罄锩娴姆椒ɑ驅(qū)傩?,現(xiàn)有的單繼承機(jī)制就不能滿足要求。與繼承相比,接口有更高的靈活性, 因?yàn)榻涌谥袥](méi)有任何實(shí)現(xiàn)代碼。當(dāng)一個(gè)類實(shí)現(xiàn)了接口以后,該類要實(shí)現(xiàn)接口里面所有 的方法和屬性,并且接口里面的屬性在默認(rèn)狀態(tài)下面都是 public static,所有方法默認(rèn)情況下是 public.一個(gè)類可以實(shí)現(xiàn)多個(gè)接口。50、Java 中的異常處理機(jī)制的簡(jiǎn)單原理和應(yīng)用。當(dāng) JAVA 程序了 JAVA 的語(yǔ)義規(guī)則時(shí),JAVA

40、虛擬機(jī)就會(huì)將發(fā)生的錯(cuò)誤表示為一個(gè)異常。越界,會(huì)語(yǔ)義規(guī)則包括 2 種情況。一種是 JAVA 類庫(kù)內(nèi)置的語(yǔ)義檢查。例如數(shù)組下標(biāo)null 的對(duì)象時(shí)會(huì)程序員擴(kuò)展這種語(yǔ)義檢查,程序員可IndexOutOfBoundsException;NullPointerException。另一種情況就是 JAVA以創(chuàng)建的異常,并自由選擇在何時(shí)用 throw 關(guān)鍵字異常。所有的異常都是java.lang.Thowable 的子類。51、回收的優(yōu)點(diǎn)和原理。并考慮 2 種回收機(jī)制。Java 語(yǔ)言中一個(gè)顯著的特點(diǎn)就是引入了回收機(jī)制,使 c+程序員最頭疼的內(nèi)存管理的問(wèn)題迎刃而解,它使得 Java 程序員在編寫(xiě)程序的時(shí)候不再需

41、要考慮內(nèi)存管理。由于有個(gè)回收機(jī)制,Java 中的對(duì)象不再有“作用域”的概念,只有對(duì)象的才有“作用域”。回收可以有效的防止內(nèi)存泄露,有效的使用可以使用的內(nèi)存?;厥掌魍ǔJ亲鳛橐粋€(gè)單獨(dú)的低級(jí)別的線程運(yùn)行,不可預(yù)知的情況下對(duì)內(nèi)存堆中已經(jīng)的或者長(zhǎng)時(shí)間沒(méi)有使用的對(duì)象進(jìn)行清楚和回收,程序員不能實(shí)時(shí)的調(diào)用回收器對(duì)某個(gè)對(duì)象或所有對(duì)象進(jìn)行回收?;厥諜C(jī)制有分代回收和標(biāo)記回收,增量回收。52、請(qǐng)說(shuō)出你所知道的線程同步的方法。wait():使一個(gè)線程處于等待狀態(tài),并且所持有的對(duì)象的 lock。sleep():使一個(gè)正在運(yùn)行的線程處于睡眠狀態(tài),是一個(gè)靜態(tài)方法,調(diào)用此方法要捕捉InterruptedException 異

42、常。notify():喚醒一個(gè)處于等待狀態(tài)的線程,注意的是在調(diào)用此方法的時(shí)候,并不能確切的喚醒某一個(gè)等待狀態(tài)的線程,而是由 JVM 確定喚醒哪個(gè)線程,而且不是按優(yōu)先級(jí)。Allnotity():喚醒所有處入等待狀態(tài)的線程,注意并不是給所有喚醒線程一個(gè)對(duì)象的鎖,而是讓它們競(jìng)爭(zhēng)。53、你所知道的集合類都有哪些?主要方法?最常用的集合類是 List 和 Map。 List 的具體實(shí)現(xiàn)包括 ArrayList 和 Vector,它們是可變大小的列表,比較適合構(gòu)建、和操作任何類型對(duì)象的元素列表。 List 適用于按數(shù)值索引元素的情形。Map 提供了一個(gè)更通用的元素方法。 Map 集合類用于元素對(duì)(稱作“鍵

43、”和“值”),其中每個(gè)鍵到一個(gè)值。54、描述一下 JVM 加載 class 文件的原理機(jī)制?JVM 中類的裝載是由 ClassLoader 和它的子類來(lái)實(shí)現(xiàn)的,Java ClassLoader 是一個(gè)重要的 Java 運(yùn)行時(shí)系統(tǒng)組件。它負(fù)責(zé)在運(yùn)行時(shí)查找和裝入類文件的類。55、char 型變量中能不能存貯一個(gè)中文漢字?為什么?能夠定義成為一個(gè)中文的,因?yàn)?java 中以 unicode 編碼,一個(gè) char 占 16 個(gè)字節(jié),所以放一個(gè)中文是沒(méi)問(wèn)題的56、多線程有幾種實(shí)現(xiàn)方法,都是什么?同步有幾種實(shí)現(xiàn)方法,都是什么?多線程有兩種實(shí)現(xiàn)方法,分別是繼承 Thread 類與實(shí)現(xiàn) Runnable 接口

44、同步的實(shí)現(xiàn)方面有兩種,分別是 synchronized,wait 與 notify57、JSP 的內(nèi)置對(duì)象及方法。request 表示 HttpServletRequest 對(duì)象。它包含了有關(guān)瀏覽器請(qǐng)求的信息,并且提供了幾個(gè)用于獲取 cookie, header, 和 session 數(shù)據(jù)的有用的方法。response 表示 HttpServletResponse 對(duì)象,并提供了幾個(gè)用于設(shè)置送回 瀏覽器的響應(yīng)的方法(如 cookies,頭信息等)out 對(duì)象是 javax.jsp.JspWriter 的一個(gè)實(shí)例,并提供了幾個(gè)方法使你能用于向?yàn)g覽器回送輸出結(jié)果。pageContext 表示一個(gè)

45、javax.servlet.jsp.PageContext 對(duì)象。它是用于方便存取各種范圍的名字空間、servlet 相關(guān)的對(duì)象的 API,并且包裝了通用的 servlet 相關(guān)功能的方法。session 表示一個(gè)請(qǐng)求的 javax.servlet.http.HttpSession 對(duì)象。Session 可以存貯用戶的狀態(tài)信息applicaton 表示一個(gè) javax.servle.ServletContext 對(duì)象。這有助于查找有關(guān) servlet 引擎和 servlet 環(huán)境的信息config 表示一個(gè) javax.servlet.ServletConfig 對(duì)象。該對(duì)象用于存取 serv

46、let 實(shí)例的初始化參數(shù)。page 表示從該頁(yè)面產(chǎn)生的一個(gè) servlet 實(shí)例58、線程的基本概念、線程的基本狀態(tài)以及狀態(tài)之間的關(guān)系線程指在程序執(zhí)行過(guò)程中,能夠執(zhí)行程序代碼的一個(gè)執(zhí)行個(gè)線程,也就是程序本身。,每個(gè)程序至少都有一Java 中的線程有四種狀態(tài)分別是:運(yùn)行、就緒、掛起、結(jié)束。59、JSP 的常用指令<%page language=”java” contenType=”text/html;charset=gb2312” session=”true” buffer=”64kb” autoFlush=”true” isThreadSafe=”true” info=”text” er

47、rorPage=”error.jsp” isErrorPage=”true” isELIgnored=”true” pageEncoding=”gb2312” import=”java.sql.*”%>isErrorPage(是否能使用 Exception 對(duì)象),isELIgnored(是否忽略表達(dá)式)<%include file=”filename”%><%taglib prefix=”c”uri=”http:/”%>60、什么情況下調(diào)用 doGet()和 doPost()?Jsp 頁(yè)面中的 formdoPost()。里的 method 屬性為 get 時(shí)調(diào)用

48、 doGet(),為 post 時(shí)調(diào)用61、servlet 的生命周期web 容器加載 servlet,生命周期開(kāi)始。通過(guò)調(diào)用 servlet 的 init()方法進(jìn)行 servlet 的初始化。通過(guò)調(diào)用 service()方法實(shí)現(xiàn),根據(jù)請(qǐng)求的不同調(diào)用不同的 do*()方法。結(jié)束服務(wù),web 容器調(diào)用 servlet 的 destroy()方法。62、如何現(xiàn)實(shí) servlet 的單線程模式<% page isThreadSafe=”false”%>63、頁(yè)面間對(duì)象傳遞的方法request,session,application,cookie 等64、JSP 和 Servlet 有哪

49、些相同點(diǎn)和不同點(diǎn),他們之間的是什么?JSP 是 Servlet 技術(shù)的擴(kuò)展,本質(zhì)上是 Servlet 的簡(jiǎn)易方式,更強(qiáng)調(diào)應(yīng)用的外表表達(dá)。JSP 編譯后是"類 servlet"。Servlet 和 JSP 最主要的不同點(diǎn)在于,Servlet 的應(yīng)用邏輯是在 Java 文件中,并且完全從表示層中的 HTML 里分離開(kāi)來(lái)。而 JSP 的情況是 Java 和HTML 可以組輯。一個(gè)擴(kuò)展名為.jsp 的文件。JSP 側(cè)重于視圖,Servlet 主要用于邏65、四種會(huì)話跟蹤技術(shù)會(huì)話作用域 ServletsJSP 頁(yè)面描述page 否是代表與一個(gè)頁(yè)面相關(guān)的對(duì)象和屬性。一個(gè)頁(yè)面由一個(gè)編譯好

50、的 Java servlet類(可以帶有任何的 include 指令,但是沒(méi)有 include 動(dòng)作)表示。這既包括 servlet又包括被編譯成 servlet 的 JSP 頁(yè)面request 是是代表與 Web 客戶機(jī)發(fā)出的一個(gè)請(qǐng)求相關(guān)的對(duì)象和屬性。一個(gè)請(qǐng)求可能跨越多個(gè)頁(yè)面,涉及多個(gè) Web 組件(由于 forward 指令和 include 動(dòng)作的關(guān)系)session 是是代表與用于某個(gè) Web 客戶機(jī)的一個(gè)用戶體驗(yàn)相關(guān)的對(duì)象和屬性。一個(gè)Web 會(huì)話可以也經(jīng)常會(huì)多個(gè)客戶機(jī)請(qǐng)求application 是是代表與整個(gè) Web 應(yīng)用程序相關(guān)的對(duì)象和屬性。這實(shí)質(zhì)上是Web 應(yīng)用程序,包括多個(gè)頁(yè)面

51、、請(qǐng)求和會(huì)話的一個(gè)全局作用域整個(gè)66、Request 對(duì)象的主要方法:setAttribute(String name,Object):設(shè)置名字為 name 的 request 的參數(shù)值getAttribute(String name):返回由 name 指定的屬性值getAttributeNames():返回 request 對(duì)象所有屬性的名字集合,結(jié)果是一個(gè)枚舉的實(shí)例getCookies():返回客戶端的所有 Cookie 對(duì)象,結(jié)果是一個(gè) Cookie 數(shù)組getCharacterEncoding():返回請(qǐng)求中的字符編碼方式getContentLength():返回請(qǐng)求的 Body 的

52、長(zhǎng)度getHeader(String name):獲得 HTTP 協(xié)議定義的文件頭信息getHeaders(String name):返回指定名字的 request Header 的所有值,結(jié)果是一個(gè)枚舉的實(shí)例getHeaderNames():返回所以 request Header 的名字,結(jié)果是一個(gè)枚舉的實(shí)例getInputStream():返回請(qǐng)求的輸入流,用于獲得請(qǐng)求中的數(shù)據(jù)getMethod():獲得客戶端向服務(wù)器端傳送數(shù)據(jù)的方法getParameter(String name):獲得客戶端傳送給服務(wù)器端的有 name 指定的參數(shù)值getParameterNames():獲得客戶端傳送

53、給服務(wù)器端的所有參數(shù)的名字,結(jié)果是一個(gè)枚舉的實(shí)例getParameterValues(String name):獲得有 name 指定的參數(shù)的所有值getProtocol():獲取客戶端向服務(wù)器端傳送數(shù)據(jù)所依據(jù)的協(xié)議名稱getQueryString():獲得字符串getRequestURI():獲取發(fā)出請(qǐng)求字符串的客戶端地址getRemoteAddr():獲取客戶端的 IP 地址getRemoteHost():獲取客戶端的名字getSession(Boolean create):返回和請(qǐng)求相關(guān) SessiongetServerName():獲取服務(wù)器的名字getServletPath():獲取

54、客戶端所請(qǐng)求的文件的路徑getServerPort():獲取服務(wù)器的端removeAttribute(String name):刪除請(qǐng)求中的一個(gè)屬性67、J2EE 是技術(shù)還是平臺(tái)還是框架?J2EE 本身是一個(gè)標(biāo)準(zhǔn),一個(gè)為企業(yè)分布式應(yīng)用的開(kāi)發(fā)提供的標(biāo)準(zhǔn)平臺(tái)。J2EE 也是一個(gè)框架,包括 JDBC、JNDI、RMI、JMS、EJB、JTA 等技術(shù)。68、我們?cè)?web 應(yīng)用開(kāi)發(fā)過(guò)程中經(jīng)常遇到輸出某種編碼的字符,如 iso8859-1 等,如何輸出一個(gè)某種編碼的字符串?Public String translate (String str) String tempStr = ""

55、try tempStr = new String(str.getBytes("ISO-8859-1"), "GBK"); tempStr = tempStr.trim();catch (Exception e) System.err.println(e.getMessage();return tempStr;69、簡(jiǎn)述邏輯操作(&,|,)與條件操作(&&,|)的區(qū)別。區(qū)別主要答兩點(diǎn):a.條件操作只能操作布爾型的,而邏輯操作不僅可以操作布爾型,而且可以操作數(shù)值型b.邏輯操作產(chǎn)生短路70、XML 文檔定義有幾種形式?它們之間有何本質(zhì)區(qū)

56、別?式?XML 文檔有哪幾種方a: 兩種形式 dtd schema,b: 本質(zhì)區(qū)別:schema 本身是 xml 的,可以ML器解析(這也是從 DTD 上發(fā)展 schema 的根本目的),c:有 DOM,SAX,STAX 等DOM:處理大型文件時(shí)其性能下降的非常厲害。這個(gè)問(wèn)題是由 DOM 的樹(shù)結(jié)構(gòu)所造成的,這種結(jié)構(gòu)占用的內(nèi)存較多,而且 DOM 必須在適合對(duì) XML 的隨機(jī)文件之前把整個(gè)文檔裝入內(nèi)存,SAX:不現(xiàn)于 DOM,SAX 是驅(qū)動(dòng)型的 XML方式。它順序XML 文件,不需要一次全部裝載整個(gè)文件。當(dāng)遇到像文件開(kāi)頭,文檔結(jié)束,或者開(kāi)頭與結(jié)束時(shí),它會(huì)觸發(fā)一個(gè)合對(duì) XML 的順序,用戶通過(guò)在其回調(diào)中寫(xiě)入處理代碼來(lái)處理 XML 文件,

溫馨提示

  • 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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 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)論