JSP面試題及答案_第1頁
JSP面試題及答案_第2頁
JSP面試題及答案_第3頁
JSP面試題及答案_第4頁
JSP面試題及答案_第5頁
已閱讀5頁,還剩10頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、JSP面試題及答案1. 瀏覽器 jsp,html 之間的關(guān)系1. JSP與Java Servlet 一樣,是在服務(wù)器端執(zhí)行的,通常返回該客戶端的就是一個HTMI文本,因此客戶端只要有瀏覽器就能瀏覽2. 在大多數(shù)Browser/Server結(jié)構(gòu)的Web應(yīng)用中,瀏覽器直接通過 HTML或者JSP的形式與用戶交互,響 應(yīng)用戶的請求3. JSP在服務(wù)器上執(zhí)行,并將執(zhí)行結(jié)果輸出到客戶端瀏覽器,我們可以說基本上與瀏覽器無關(guān)2. 自定義標(biāo)簽要繼承哪個類這個類可以繼承 TagSupport 或者 BodyTagSupport ,兩者的差別是前者適用于沒有主體的標(biāo)簽,而后 者適用于有主體的標(biāo)簽。如果選擇繼承 T

2、agSupport ,可以實(shí)現(xiàn) doStartTag 和 doEndTag 兩個方法實(shí)現(xiàn) Tag 的功能,如果選擇繼承 BodyTagSupport ,可以實(shí)現(xiàn) doAfterBody 這個方法。3. 過濾器 Filter 的作用及配置過濾器的作用 :過濾器是一個對象, 可以傳輸請求或修改響應(yīng)。 它可以在請求到達(dá) Servlet/JSP 之前對其進(jìn)行預(yù)處理, 而且能夠在響應(yīng)離開 Servlet/JSP 之后對其進(jìn)行后處理。所以如果你有幾個 Servlet/JSP 需要執(zhí)行同樣的 數(shù)據(jù)轉(zhuǎn)換或頁面處理的話,你就可以寫一個過濾器類,然后在部署描述文件(web.xml)中把該過濾器與對應(yīng)的 Servl

3、et/JSP 聯(lián)系起來。你可以一個過濾器以作用于一個或一組 servlet ,零個或多個過濾器能過濾 一個或多個 servlet 。一個過濾器實(shí)現(xiàn) java.servlet.Filter 接口并定義它的三個方法:1 void init(FilterConfig config) throws ServletException:在過濾器執(zhí)行 service 前被調(diào)用,以設(shè)置過濾器的配置對象。2 void destroy(); 在過濾器執(zhí)行 service 后被調(diào)用。3 Void doFilter(ServletRequest req,ServletResponse res,F(xiàn)ilterChain

4、chain) throws IOExcep tion,ServletException;4. forward, 與 redirect 的區(qū)別 ?有哪些方式實(shí)現(xiàn)forward 是把另一個頁面加載到本頁面,不改變?yōu)g覽器的路徑,redirect 是跳轉(zhuǎn)到另一個頁面,會改變?yōu)g覽器的路徑重定向 : response.sendRedirect(" 重定向的路徑 ")轉(zhuǎn)發(fā) : request.getRequestDispatcher("轉(zhuǎn)發(fā)路徑 ").forward(request, response);5. jsp 內(nèi)置對象和作用?有九個內(nèi)置對象: request

5、、response 、out 、session 、 application 、pageContext 、 config 、page、 exception作用如下:(1) HttpServletRequest 類的 Request 對象作用:代表請求對象,主要用于接受客戶端通過HTTP協(xié)議連接傳輸?shù)椒?wù)器端的數(shù)據(jù)。(2) HttpServletResponse 類的 Respone 對象作用:代表響應(yīng)對象,主要用于向客戶端發(fā)送數(shù)據(jù)(3) JspWriter 類的 out 對象 作用:主要用于向客戶端輸出數(shù)據(jù) ;Out 的基類是 JspWriter(4) HttpSession 類的 sessio

6、n 對象 作用:主要用于來分別保存每個用戶信息,與請求關(guān)聯(lián)的會話;會話狀態(tài)維持是Web應(yīng)用開發(fā)者必須面對的問題。(5) ServletContex 類的 application 對象 作用:主要用于保存用戶信息,代碼片段的運(yùn)行環(huán)境;它是一個共享的內(nèi)置對象,即一個容器中的多個用戶共享一個 application 對象,故其保存 的信息被所有用戶所共享 .(6) PageContext 類的 PageContext 對象作用:管理網(wǎng)頁屬性,為JSP頁面包裝頁面的上下文,管理對屬于JSP中特殊可見部分中已命名對象的訪問,它的創(chuàng)建和初始化都是由容器來完成的。(7) ServletConfig 類的 C

7、onfig 對象 作用:代碼片段配置對象,表示 Servlet 的配置。(8) Object 類的Page (相當(dāng)于this )對象作用:處理JSP網(wǎng)頁,是Object類的一個實(shí)例,指的是 JSP實(shí)現(xiàn)類的實(shí)例,即它也是 JSP本身,只有 在JSP頁面范圍之內(nèi)才是合法的。(9) Exception作用:處理JSP文件執(zhí)行時發(fā)生的錯誤和異常6. 如果用JSP開發(fā)一個聊天程序,不用數(shù)據(jù)庫存儲聊天紀(jì)錄,請問聊天記錄最好存儲在()中。Application7. doPost,doGet 的區(qū)別 ?1。 當(dāng)你直接訪問一個 servlet時,調(diào)用的是doGet方法。2。如果你的 html 里面規(guī)定了 met

8、hod 訪問哪個方法,則調(diào)用該方法。3。get 和 post 提交的數(shù)據(jù)量是不一樣的 .get 好像最多只能在 url 后跟 8K, post 沒這個限制8. jsp 亂碼如何解決,幾種解決方案。?一、JSP 頁面顯示亂碼二、表單提交中文時出現(xiàn)亂碼三、數(shù)據(jù)庫連接時出現(xiàn)亂碼9. 頁面間對象傳遞的方法request,session,application,cookie等request.setAttribute(key,value) session.setAttribute(key,value)application.setAttribute(key,value)10. 我們在 web 應(yīng)用開發(fā)過程

9、中經(jīng)常遇到輸出某種編碼的字符, 如 iso8859-1 等,如何輸出一個某種編碼 的字符串?text = new String( text.getBytes(“iso8859 -1”), ”GBK”);首先以“ iso8859 -1”解碼為byte數(shù)組,再用“ GBK重構(gòu)字符串11. 簡單介紹一下 servletservlet 容器:負(fù)責(zé)處理客戶請求、把請求傳送給 servlet 并把結(jié)果返回給客戶。不同程序的容器實(shí)際實(shí)現(xiàn)可能有所 變化,但容器與 servlet 之間的接口是由 servletAPI 定義好的,這個接口定義了 servlet 容器在 servlet 上要調(diào)用的方法及傳遞給 se

10、rvlet 的對象類。servlet 的生命周期:servlet 容器創(chuàng)建 servlet 的一個實(shí)例容器調(diào)用該實(shí)例的 init() 方法如果容器對該 servlet 有請求,則調(diào)用此實(shí)例的 service() 方法 容器在銷毀本實(shí)例前調(diào)用它的 destroy() 方法銷毀并標(biāo)記該實(shí)例以供作為垃圾收集一旦請求了一個 servlet ,就沒有辦法阻止容器執(zhí)行一個完整的生命周期。容器在 servlet 首次被調(diào)用時創(chuàng)建它的一個實(shí)例,并保持該實(shí)例在內(nèi)存中,讓它對所有的請求進(jìn)行處 理。容器可以決定在任何時候把這個實(shí)例從內(nèi)存中移走。在典型的模型中,容器為每個servlet 創(chuàng)建一個單獨(dú)的實(shí)例,容器并不會

11、每接到一個請求就創(chuàng)建一個新線程,而是使用一個線程池來動態(tài)的將線程分配給 到來的請求,但是這從 servlet 的觀點(diǎn)來看,效果和為每個請求創(chuàng)建一個新線程的效果相同。12. BS與CS的聯(lián)系與區(qū)別。B/S模式是指在TCP/IP的支持下,以HTTP為傳輸協(xié)議,客戶端通過 Browser訪問Web服務(wù)器以及與 之相連的后臺數(shù)據(jù)庫的技術(shù)及體系結(jié)構(gòu)。它由瀏覽器、Web服務(wù)器、應(yīng)用服務(wù)器和數(shù)據(jù)庫服務(wù)器組成??蛻舳说臑g覽器通過URL訪問Web服務(wù)器,Wet服務(wù)器請求數(shù)據(jù)庫服務(wù)器,并將獲得的結(jié)果以HTML形式返回客戶端瀏覽器。c/s 在系統(tǒng)機(jī)構(gòu)上和 B/S 相似,不過需要在客戶端安裝一個客戶端軟件,由這個軟件

12、對服務(wù)器的數(shù)據(jù) 進(jìn)行讀寫,就像我們常用的 qq,就是這種模式。13. JSP與 SERVLET的區(qū)別。JSP先編譯成SERVLET然后再編譯成CLASS文件JSPSERVLETJAVA 文件 -CLASSjsp 主要做視圖層, servlet 主要做控制層14.JSP中動態(tài)INCLUDE與靜態(tài)INCLUDE的 區(qū)另 U?動態(tài)INCLUDE用 jsp:include動作實(shí)現(xiàn)它總是會檢查所含文件中的變化,適合用于包含動態(tài)頁面,并且可以帶參數(shù)。靜態(tài)INCLUDE用 include偽碼實(shí)現(xiàn),定不會檢查所含文件的變化,適用于包含靜態(tài)頁面15. JSP 的內(nèi)置對象及方法。9 大內(nèi)置對象: request,

13、response,pagecontext,session,application,out,config,page,exception request-HttpServletRequest的子類response-HttpServletResponse的子類session-HttpSession的子類pagecontext-PageContext的子類application-ServletContext的子類out-JspWriter的子類config-ServletConfig的子類page-Object 的子類 exception-Throwab的子類16. 四種會話跟蹤技術(shù)會話跟蹤是為了跟蹤

14、用戶于 service 之間的多次交互 .1. cookie 也就是我們常見的在 C盤/文件夾下有一個COOKIE目錄2. session 比 Cookie 安全 . 不可見 . 但占用 srevice 資源3. url 重寫 . 這是在用戶的 IE 禁止 Cookie 的時候采用的方法。因?yàn)椴还苁?Cookie 還是 session 都要借助4. 隱藏域17. <%,%和> <%!,%>的區(qū)別<%,%用> 于在 JSP 頁面中嵌入 Java 腳本<%!,%:用于在 JSP頁面中申明變量或方法,可以在該頁面中的<%,%腳本中調(diào)用,聲明的變量相當(dāng)于

15、Servlet 中的定義的成員變量。18. 你認(rèn)為哪種分頁效率最高 ? JSP ,MYSQL,SQL2005.SQL2005效率高:因?yàn)閙ysql的分頁還是先查出所有的記錄,再從起始位置開始查出所需要的記錄,而SQL2005不會查所有記錄,只查篩選后所需要的記錄19. 簡單說明下你對 servlet 的認(rèn)識及其 Servlet 的基本架構(gòu)、生命周期HttpServlet 類是一個抽象類,可以從該類派生出一個子類來實(shí)現(xiàn)一個HttpServlet ,接受來自Web站點(diǎn)的請求(該請求來自訪問該Web站點(diǎn)的客戶瀏覽器),并將處理后的響應(yīng)結(jié)果發(fā)回Web站點(diǎn)(Web站點(diǎn)再將響應(yīng)結(jié)果發(fā)送給客戶瀏覽器) ,在

16、 HttpServlet 的子類中,必須至少重載下表中的其中一種方法。 方法名 doGet如果 Servlet 支持 Http GET 請求,用于 Http GET 請求 doPost如果 Servlet 支持 Http POST 請求,用于 Http POST 請求 doPut如果 Servlet 支持 Http PUT 請求,用于 Http PUT 請求 doDelete如果 Servlet 支持 Http DELETE 請求,用于 Http DELETE 請求init 和 destroy如果需要管理 Servlet 生命周期內(nèi)所持有資源,可以重載這兩個方法通常,不重載 service 方

17、法,對于上表中的每一種HTTP 請求, service 方法通過分派它們到相應(yīng)的Handler線程(doXXX方法)來處理這些標(biāo)準(zhǔn)的HTTP請求。同樣地,通常也不重載 doOptions和doTrace方法,service 方法通過分派它們到 doTrace和doOptions 來支持 HTTP1.1 TRACE和 OPTIONSServlet 通常運(yùn)行在多線程的服務(wù)器中,因此,所編寫的 Servlet 代碼必須能夠處理并行請求和對數(shù) 據(jù)資源的同步訪問。共享資源包括內(nèi)存中的數(shù)據(jù)(例如:實(shí)例或類變量)和外部對象(例如:文件、數(shù)據(jù) 庫連接或網(wǎng)絡(luò)連接) 。Protected void doGet(H

18、ttpServletRequest req,HttpServletResponse resp)throws ServletException,IOException從service方法授并處理HTTP GE請求。GET方法允許客戶讀取來自Web服務(wù)器的信息,客戶通過傳遞一個帶URL的查詢字符串可以告訴服務(wù)器它需什么信息。重載支持GET請求的doGet方法還將自動支持 HTTP HEAD青求,HEAD#求也是一個 GET請求,它得到 的返回響應(yīng)中只有一個請求頭(header)字段,而沒有響應(yīng)信息的內(nèi)容。如果重載方法,應(yīng)該從該請求讀數(shù)據(jù),在響應(yīng)中設(shè)置整個 headers ,訪問 PrintWrit

19、er 或輸出流對象, 最后寫響應(yīng)數(shù)據(jù)。當(dāng)設(shè)置 headers 時,應(yīng)確保包含 content type 和 encoding 。如果使用 PrintWriter 對 象返回響應(yīng),在存取 PrintWriter 對象之前必須設(shè)置 content type 。Servlet 引擎必須在寫響應(yīng)數(shù)據(jù)之前寫 headers ,因?yàn)樵趯憯?shù)據(jù)之后 headers 隨時都可能被刷新。20. 簡單描述下數(shù)據(jù)連接池的工作機(jī)制是什么?數(shù)據(jù)庫連接池在初始化時將創(chuàng)建一定數(shù)量的數(shù)據(jù)庫連接放到連接池中,這些數(shù)據(jù)庫連接的數(shù)量是由最 小數(shù)據(jù)庫連接數(shù)來設(shè)定的。 無論這些數(shù)據(jù)庫連接是否被 使用, 連接池都將一直保證至少擁有這么多的

20、連接 數(shù)量。連接池的最大數(shù)據(jù)庫連接數(shù)量限定了這個連接池能占有的最大連接數(shù),當(dāng)應(yīng)用程序向連接池請求的 連接數(shù)超 過最大連接數(shù)量時,這些請求將被加入到等待隊(duì)列中。數(shù)據(jù)庫連接池的最小連接數(shù)和最大連接數(shù)的設(shè)置要考慮到下列幾個因素:1)最小連接數(shù)是連接池一直保持的數(shù)據(jù)庫連接, 所以如果應(yīng)用程序?qū)?shù)據(jù)庫連接的使用量不大, 將會 有大量的數(shù)據(jù)庫連接資源被浪費(fèi);2)最大連接數(shù)是連接池能申請的最大連接數(shù),如果數(shù)據(jù)庫連接請求超過此數(shù),后面的數(shù)據(jù)庫連接請 求將被加入到等待隊(duì)列中,這會影響之后的數(shù)據(jù)庫操作。3)如果最小連接數(shù)與最大連接數(shù)相差太大, 那么最先的連接請求將會獲利, 之后超過最小連接數(shù)量的 連接請求等價于建

21、立一個新的數(shù)據(jù)庫連接。不過,這些大于最小連接數(shù)的數(shù)據(jù)庫連接在使用完不會馬上被 釋放,它將被放到連接池中等待重復(fù)使用或是空閑超時后被釋放 。21. jsp 亂碼如何解決,給出三種以上的對應(yīng)解決方案,并給出對應(yīng)的程序案例;一、JSP 頁面顯示亂碼<% page contentType="text/html; charset=gb2312"%>二、表單提交中文時出現(xiàn)亂碼request.seCharacterEncoding(“gb2312” )對請求進(jìn)行統(tǒng)一編碼三、數(shù)據(jù)庫連接出現(xiàn)亂碼要 涉及 中 文 的 地 方 全 部 是 亂碼 , 解 決 辦 法 :在 數(shù)據(jù) 庫的

22、數(shù)據(jù) 庫 URL 中 加 上 useUnicode=true&characterEncoding=GBK就 OK了。四、通過過濾器完成五、 在server.xml中的設(shè)置編碼格式22. 面向?qū)ο蟮奶卣饔心男┓矫?. 抽象:抽象就是忽略一個主題中與當(dāng)前目標(biāo)無關(guān)的那些方面,以便更充分地注意與當(dāng)前目標(biāo)有關(guān)的方面。抽 象并不打算了解全部問題,而只是選擇其中的一部分,暫時不用部分細(xì)節(jié)。抽象包括兩個方面,一是過程 抽象,二是數(shù)據(jù)抽象。2. 繼承:繼承是一種聯(lián)結(jié)類的層次模型,并且允許和鼓勵類的重用,它提供了一種明確表述共性的方法。對象 的一個新類可以從現(xiàn)有的類中派生,這個過程稱為類繼承。新類繼承了原

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

24、?基本數(shù)據(jù)類型包括 byte、int、char、long、float、double、boolean 和 short 。java.Iang.String 類是final類型的,因此不可以繼承這個類、不能修改這個類。為了提高效率節(jié)省 空間,我們應(yīng)該用 StringBuffer 類24. int 和Integer有什么區(qū)別Java提供兩種不同的類型:引用類型和原始類型(或內(nèi)置類型)oInt是java的原始數(shù)據(jù)類型Integer 是java為int提供的封裝類。Java為每個原始類型提供了封裝類。原始類型圭寸裝類:booleanBoolean charCharacter byteByte shortS

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

26、可改變的字符串。而這個StringBuffer類提供的字符串進(jìn)行修改。當(dāng)你知道字符數(shù)據(jù)要改變的時候你就可以使用StringBuffer 。典型地,你可以使用StringBuffers 來動態(tài)構(gòu)造字符數(shù)據(jù)。26. 運(yùn)行時異常與一般異常有何異同?異常表示程序運(yùn)行過程中可能岀現(xiàn)的非正常狀態(tài),運(yùn)行時異常表示虛擬機(jī)的通常操作中可能遇到的異 常,是一種常見運(yùn)行錯誤。java編譯器要求方法必須聲明拋岀可能發(fā)生的非運(yùn)行時異常,但是并不要求必 須聲明拋出未被捕獲的運(yùn)行時異常。27. 說出ArrayList,Vector, LinkedList的存儲性能和特性ArrayList和Vector都是使用數(shù)組方式存儲數(shù)

27、據(jù),此數(shù)組元素數(shù)大于實(shí)際存儲的數(shù)據(jù)以便增加和插入 元素,它們都允許直接按序號索引元素,但是插入元素要涉及數(shù)組元素移動等內(nèi)存操作,所以索引數(shù)據(jù)快 而插入數(shù)據(jù)慢,Vector由于使用了 synchronized方法(線程安全),通常性能上較ArrayList差,而LinkedList使用雙向鏈表實(shí)現(xiàn)存儲,按序號索引數(shù)據(jù)需要進(jìn)行前向或后向遍歷,但是插入數(shù)據(jù)時只需要記 錄本項(xiàng)的前后項(xiàng)即可,所以插入速度較快。28. Collection 和 Collections 的區(qū)別。Collection是集合類的上級接口,繼承與他的接口主要有Set和List.Collections是針對集合類的一個幫助類,他提供

28、一系列靜態(tài)方法實(shí)現(xiàn)對各種集合的搜索、排序、線程安全化等操作。29. &和&&勺區(qū)別。&和&&都可作為邏輯運(yùn)算符“與”使用,但是&&是“短路與”,運(yùn)算時先判斷符號前面的表達(dá)式的值,如果能夠確定整個表達(dá)式的值,則不進(jìn)行符號后面的表達(dá)式的運(yùn)算。另外,&也可作為位運(yùn)算符使用。30. HashMap和 Hashtable 的區(qū)別。HashMap是Hashtable的輕量級實(shí)現(xiàn)(非線程安全的實(shí)現(xiàn)),他們都完成了Map接口,主要區(qū)別在于HashMap允許空(null )鍵值(key),由于非線程安全,效率上可能高于Hashtable。H

29、ashMap允許將 null 作為一個 entry 的 key 或者 value,而 Hashtable 不允許。HashMap把 Hashtable 的 contains 方法去掉了,改成 containsvalue 和 containsKey 。因?yàn)?contains 方法容易讓人引起誤解。Hashtable 繼承自 Dictionary 類,而 HashMap是 Java1.2 引進(jìn)的 Map interface 的一個實(shí)現(xiàn)。最大的不同是, Hashtable的方法是 Synchronize 的,而HashMap不是,在多個線程訪問Hashtable時,不需要自己為它的方法實(shí)現(xiàn)同步,而H

30、ashMap就必須為之提供外同步。Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會有很大的差異。31. final, finally, finalize的區(qū)別。final用于聲明屬性,方法和類,分別表示屬性不可變,方法不可覆蓋,類不可繼承。finally是異常處理語句結(jié)構(gòu)的一部分,表示總是執(zhí)行。finalize 是Object類的一個方法,在垃圾收集器執(zhí)行的時候會調(diào)用被回收對象的此方法,可以覆蓋 此方法提供垃圾收集時的其他資源回收,例如關(guān)閉文件等。32. sleep() 和wait()有什么區(qū)別sleep是線程類(Thread )的方法,導(dǎo)致此線程暫停

31、執(zhí)行指定時間,給執(zhí)行機(jī)會給其他線程,但是監(jiān)控狀態(tài)依然保持,到時后會自動恢復(fù)。調(diào)用sleep不會釋放對象鎖。wait是Object類的方法,對此對象調(diào)用wait方法導(dǎo)致本線程放棄對象鎖,進(jìn)入等待此對象的等待鎖定池,只有針對此對象發(fā)出notify 方法(或notifyAll )后本線程才進(jìn)入對象鎖定池準(zhǔn)備獲得對象鎖進(jìn)入運(yùn)行狀態(tài)。33. Overload和Override的區(qū)別。Overloaded的方法是否可以改變返回值的類型?方法的重寫Overriding 和重載Overloading是Java多態(tài)性的不同表現(xiàn)。重寫Overriding 是父類與子類之間多態(tài)性的一種表現(xiàn),重載 Overloadi

32、ng是一個類中多態(tài)性的一種表現(xiàn)。如果在子類中定義某方法 與其父類有相同的名稱和參數(shù),我們說該方法被重寫(Overriding)。子類的對象使用這個方法時,將調(diào)用子類中的定義,對它而言,父類中的定義如同被"屏蔽"了。如果在一個類中定義了多個同名的方法,它們或有不同的參數(shù)個數(shù)或有不同的參數(shù)類型,則稱為方法的重載(Overloading) 。Overloaded的方法是可以改變返回值的類型。34. error和exception 有什么區(qū)別?error表示恢復(fù)不是不可能但很困難的情況下的一種嚴(yán)重問題。比如說內(nèi)存溢出。不可能指望程序能 處理這樣的情況。exception表示一種設(shè)計

33、或?qū)崿F(xiàn)問題。也就是說,它表示如果程序運(yùn)行正常,從不會發(fā)生的情況。35. 同步和異步有何異同,在什么情況下分別使用他們?舉例說明。如果數(shù)據(jù)將在線程間共享。例如正在寫的數(shù)據(jù)以后可能被另一個線程讀到,或者正在讀的數(shù)據(jù)可能已 經(jīng)被另一個線程寫過了,那么這些數(shù)據(jù)就是共享數(shù)據(jù),必須進(jìn)行同步存取。當(dāng)應(yīng)用程序在對象上調(diào)用了一個需要花費(fèi)很長時間來執(zhí)行的方法,并且不希望讓程序等待方法的返回時,就應(yīng)該使用異步編程,在很多情況下采用異步途徑往往更有效率。36. abstract class 和 interface 有什么區(qū)別?聲明方法的存在而不去實(shí)現(xiàn)它的類被叫做抽象類( abstract class ),它用于要創(chuàng)建

34、一個體現(xiàn)某些基 本行為的類,并為該類聲明方法,但不能在該類中實(shí)現(xiàn)該類的情況。不能創(chuàng)建abstract類的實(shí)例。然而可以創(chuàng)建一個變量,其類型是一個抽象類,并讓它指向具體子類的一個實(shí)例。不能有抽象構(gòu)造函數(shù)或抽象 靜態(tài)方法。Abstract類的子類為它們父類中的所有抽象方法提供實(shí)現(xiàn),否則它們也是抽象類。取而代之, 在子類中實(shí)現(xiàn)該方法。知道其行為的其它類可以在類中實(shí)現(xiàn)這些方法。接口( interface )是抽象類的變體。在接口中,所有方法都是抽象的。多繼承性可通過實(shí)現(xiàn)這樣的 接口而獲得。接口中的所有方法都是抽象的,沒有一個有程序體。接口只可以定義static final成員變量.接口的實(shí)現(xiàn)與子類相似

35、,除了該實(shí)現(xiàn)類不能從接口定義中繼承行為。當(dāng)類實(shí)現(xiàn)特殊接口時,它定義(即將 程序體給予)所有這種接口的方法。然后,它可以在實(shí)現(xiàn)了該接口的類的任何對象上調(diào)用接口的方法。由 于有抽象類,它允許使用接口名作為引用變量的類型。通常的動態(tài)聯(lián)編將生效。引用可以轉(zhuǎn)換到接口類型 或從接口類型轉(zhuǎn)換,instanceof運(yùn)算符可以用來決定某對象的類是否實(shí)現(xiàn)了接口。37. Static Nested Class和Inner Class 的不同Static Nested Class是被聲明為靜態(tài)(static )的內(nèi)部類,它可以不依賴于外部類實(shí)例被實(shí)例化。而通常的內(nèi)部類需要在外部類實(shí)例化后才能實(shí)例化。38. GC是什么

36、?為什么要有GC?GC是垃圾收集的意思(Gabage Collection ),內(nèi)存處理是編程人員容易出現(xiàn)問題的地方,忘記或者錯 誤的內(nèi)存回收會導(dǎo)致程序或系統(tǒng)的不穩(wěn)定甚至崩潰,Java提供的GC功能可以自動監(jiān)測對象是否超過作用域從而達(dá)到自動回收內(nèi)存的目的, Java語言沒有提供釋放已分配內(nèi)存的顯示操作方法。39. short s1 = 1; s1 = s1 + 1;有什么錯? Short s1 = 1; s1 += 1;有什么錯short s1 = 1; s1 = s1 + 1;( s1+1運(yùn)算結(jié)果是int型,需要強(qiáng)制轉(zhuǎn)換類型)short s1 = 1; s1 += 1;(可以正確編譯)-wh

37、y ? A:+=運(yùn)算符無類型轉(zhuǎn)換問題!40. Math.round(11.5) 等於多少? Math.round(-11.5) 等於多少?Math.round(11.5)=12Math.round(-11.5)=-11round方法返回與參數(shù)最接近的長整數(shù),參數(shù)加 1/2后求其floor.41. String s = new String("xyz");創(chuàng)建了幾個 String Object?兩個42. 設(shè)計4個線程,其中兩個線程每次對j增加1,另外兩個線程對j每次減少1。寫出程序以下程序使用內(nèi)部類實(shí)現(xiàn)線程,對j增減的時候沒有考慮順序問題。public class Thre

38、adTest1private int j;public static void main(String args)ThreadTest1 tt=new ThreadTest1();Inc inc=tt.new Inc();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

39、()+"-inc:"+j);private synchronized void dec() j-;System.out.println(Thread.currentThread().getName()+"-dec:"+j);class Inc implements Runnablepublic void run()for(int i=0;i<100;i+)inc();class Dec implements Runnablepublic void run()for(int i=0;i<100;i+)dec();43. Java 有沒有 got

40、o?java中的保留字,現(xiàn)在沒有在 java中使用。44. 啟動一個線程是用 run()還是start()?啟動一個線程是調(diào)用 start()方法,使線程所代表的虛擬處理機(jī)處于可運(yùn)行狀態(tài),這意味著它可以由 JVM調(diào)度并執(zhí)行。這并不意味著線程就會立即運(yùn)行。run()方法可以產(chǎn)生必須退出的標(biāo)志來停止一個線程。45. 給我一個你最常見到的 runtime exception 。ArithmeticException, ArrayStoreException, BufferOverflowException,BufferUnderflowException, CannotRedoException,

41、CannotUndoException, ClassCastException, CMMException, ConcurrentModificationException, DOMException, EmptyStackException, IllegalArgumentException, IllegalMonitorStateException, IllegalPathStateException,IllegalStateException, ImagingOpException, IndexOutOfBoundsException, MissingResourceException,

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

43、抽象類是否可繼承實(shí)體類(concreteclass)?接口可以繼承接口。抽象類可以實(shí)現(xiàn)(implements)接口,抽象類可繼承實(shí)體類47. List, Set, Map 是否繼承自 Collection 接口List, Set 是,Map48. abstract 的method是否可同時是 static, 是否可同時是 native,是否可同時是 synchronized?都不能49. 數(shù)組有沒有l(wèi)ength()這個方法? String 有沒有l(wèi)ength()這個方法?數(shù)組沒有l(wèi)ength()這個方法,有l(wèi)ength的屬性。String有l(wèi)ength()這個方法。50. 構(gòu)造器 Constr

44、uctor是否可被 override?構(gòu)造器Constructor 不能被繼承,因此不能重寫 Overriding ,但可以被重載 Overloading 。51. 是否可以繼承String類?String類是final類故不可以繼承。52. swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?switch ( expr1)中,expr1是一個整數(shù)表達(dá)式。因此傳遞給switch 和case 語句的參數(shù)應(yīng)該是int、short、 char 或者 byte 。 long,string者B不能作用于 swtich 。53. try 里有一個return 語句,那么

45、緊跟在這個try后的finally 里的code會不會被執(zhí)行,什么時候被執(zhí)行,在return前還是后?會執(zhí)行,在return 前執(zhí)行。54. 編程題:用最有效率的方法算出2乘以8等於幾?2 << 355. 兩個對象值相同(x.equals(y) = true),但卻可有不同的hash code,這句話對不對?不對,有相同的 hash code。56. 當(dāng)一個線程進(jìn)入一個對象的一個synchronized方法后,其它線程是否可進(jìn)入此對象的其它方法?不能,一個對象的一個synchronized方法只能由一個線程訪問。57. 編程題:寫一個Singleton 出來。【單例模式】Singl

46、eton模式主要作用是保證在Java應(yīng)用程序中,一個類 Class只有一個實(shí)例存在。一般Singleton模式通常有幾種種形式:第一種形式:定義一個類,它的構(gòu)造函數(shù)為private的,它有一個static 的private的該類變量,在類初始化時實(shí)例話,通過一個public的getInstance方法獲取對它的引用,繼而調(diào)用其中的方法。 public class Singleton private Singleton()/在自己內(nèi)部定義自己一個實(shí)例,是不是很奇怪?/注意這是private 只供內(nèi)部調(diào)用private static Singleton instance = new Singlet

47、on();/這里提供了一個供外部訪問本class的靜態(tài)方法,可以直接訪問public static Singleton getInstance() return instance;第二種形式:public class Singleton private static Singleton instance = null;public static synchronized Singleton getInstance() /這個方法比上面有所改進(jìn),不用每次都進(jìn)行生成對象,只是第一次/使用時生成實(shí)例,提高了效率!if (instance=null)instance = new Singleton()

48、;return instance;其他形式:定義一個類,它的構(gòu)造函數(shù)為private的,所有方法為static 的。一般認(rèn)為第一種形式要更加安全些58. 請說出你所知道的線程同步的方法。wait():使一個線程處于等待狀態(tài),并且釋放所持有的對象的lock。sleep():使一個正在運(yùn)行的線程處于睡眠狀態(tài),是一個靜態(tài)方法,調(diào)用此方法要捕捉 InterruptedException 異常。notify():喚醒一個處于等待狀態(tài)的線程,注意的是在調(diào)用此方法的時候,并不能確切的喚醒某一個等待狀態(tài)的線程,而是由JVM確定喚醒哪個線程,而且不是按優(yōu)先級。Allnotity():喚醒所有處入等待狀態(tài)的線程,

49、注意并不是給所有喚醒線程一個對象的鎖,而是讓它們競爭。59. 你所知道的集合類都有哪些?主要方法?最常用的集合類是List 和Map。List的具體實(shí)現(xiàn)包括ArrayList 和Vector,它們是可變大小的列表,比較適合構(gòu)建、存儲和操作任何類型對象的元素列表。List適用于按數(shù)值索引訪問元素的情形。Map提供了一個更通用的元素存儲方法。Map集合類用于存儲元素對(稱作"鍵"和"值"),其中每個鍵映射到一個值。60. char型變量中能不能存貯一個中文漢字?為什么?能夠定義成為一個中文的,因?yàn)閖ava中以unicode編碼,一個char占16個字節(jié),所以

50、放一個中文是沒問題的61. 多線程有幾種實(shí)現(xiàn)方法,都是什么?同步有幾種實(shí)現(xiàn)方法,都是什么?多線程有兩種實(shí)現(xiàn)方法,分別是繼承Thread類與實(shí)現(xiàn)Runnable接口同步的實(shí)現(xiàn)方面有兩種,分別是 synchronized,wait 與notify62. 線程的基本概念、線程的基本狀態(tài)以及狀態(tài)之間的關(guān)系線程指在程序執(zhí)行過程中,能夠執(zhí)行程序代碼的一個執(zhí)行單位,每個程序至少都有一個線程,也就是 程序本身。Java中的線程有四種狀態(tài)分別是:運(yùn)行、就緒、掛起、結(jié)束。63. 簡述邏輯操作(&,/)與條件操作(&&,|)的區(qū)別。區(qū)別主要答兩點(diǎn):a.條件操作只能操作布爾型的,而邏輯操作不僅

51、可以操作布爾型,而且可以操作數(shù)值型b.邏輯操作不會產(chǎn)生短路64. JAVA語言如何進(jìn)行異常處理,關(guān)鍵字:throws,throw,try,catch,finally分別代表什么意義?在 try塊中可以拋岀異常嗎?Java通過面向?qū)ο蟮姆椒ㄟM(jìn)行異常處理,把各種不同的異常進(jìn)行分類,并提供了良好的接口。在Java中,每個異常都是一個對象,它是Throwable類或其它子類的實(shí)例。當(dāng)一個方法岀現(xiàn)異常后便拋岀一個異常對象,該對象中包含有異常信息,調(diào)用這個對象的方法可以捕獲到這個異常并進(jìn)行處理。Java的異常處理是通過5個關(guān)鍵詞來實(shí)現(xiàn)的:try、catch、throw > throws和finall

52、y 。一般情況下是用try來執(zhí)行一段 程序,如果出現(xiàn)異常,系統(tǒng)會拋出(throws )一個異常,這時候你可以通過它的類型來捕捉(catch )它,或最后(finally )由缺省處理器來處理。用try來指定一塊預(yù)防所有”異常"的程序。緊跟在try程序后面,應(yīng)包含一個 catch子句來指定你想 要捕捉的”異?!钡念愋?。throw語句用來明確地拋出一個"異常"。throws用來標(biāo)明一個成員函數(shù)可能拋出的各種"異常"。Finally 為確保一段代碼不管發(fā)生什么”異常"都被執(zhí)行一段代碼??梢栽谝粋€成員函數(shù)調(diào)用的外面寫一個try語句,在這個成員

53、函數(shù)內(nèi)部寫另一個try語句保護(hù)其他代碼。每當(dāng)遇到一個try語句,”異?!钡目蚣芫头诺蕉褩I厦?,直到所有的try語句都完成。如果下一級的try語句沒有對某種”異常"進(jìn)行處理,堆棧就會展開,直到遇到有處理這種”異常”的try語句。65. 一個".java"源文件中是否可以包括多個類(不是內(nèi)部類)?有什么限制?可以。必須只有一個類名與文件名相同。66. java中有幾種方法可以實(shí)現(xiàn)一個線程?用什么關(guān)鍵字修飾同步方法? stop()和suspend。方法為何不推薦使用?有兩種實(shí)現(xiàn)方法,分別是繼承Thread類與實(shí)現(xiàn)Runnable接口用synchronized 關(guān)鍵字修飾同步方法反對使用stop(),是因?yàn)樗话踩?。它會解除由線程

溫馨提示

  • 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

提交評論