JAVA復(fù)試問題答案匯總1_第1頁
JAVA復(fù)試問題答案匯總1_第2頁
JAVA復(fù)試問題答案匯總1_第3頁
JAVA復(fù)試問題答案匯總1_第4頁
JAVA復(fù)試問題答案匯總1_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

(一)復(fù)試的問題整理的優(yōu)化流程是如何實(shí)現(xiàn)的,流程是怎么樣?盡量使用,避免使用單向靈活使用單向不用一對(duì)一,使用多對(duì)一代替一對(duì)一配置對(duì)象緩存,不使用集合緩存一對(duì)多使用多對(duì)一使用繼承使用顯示多態(tài)避免查處所有對(duì)象消除大表,使用二級(jí)緩存與的區(qū)別?在實(shí)現(xiàn)類方面的對(duì)比:要求類繼承一個(gè)抽象基類;的一個(gè)具體問題是使用抽象類編程而不是接口。類可以實(shí)現(xiàn)一個(gè)接口,也可以實(shí)現(xiàn)其他接口,使可選和定制的服務(wù)成為可能。提供一基類去實(shí)現(xiàn)常用的接口。即使接口不是必須實(shí)現(xiàn)的,只有一個(gè)包含方法的類都可以用作的i線程模式方面的對(duì)比:是單例模式并且必須是線程安全的,因?yàn)閮H有的一個(gè)實(shí)例來處理所有的請(qǐng)求。單例策略限制了能做的事,并且要在開發(fā)時(shí)特別小心。資源必須是線程安全的或同步的;對(duì)象為每一個(gè)請(qǐng)求產(chǎn)生一個(gè)實(shí)例,因此沒有線程安全問題。依賴方面的對(duì)比:依賴于,因?yàn)榈姆椒ㄖ杏泻头椒?。不再依賴于,從而允許脫離容器運(yùn)行,從而降低了測試的難度。當(dāng)然,如果需要直接訪問和參數(shù),仍然可以訪問它們。但是,大部分時(shí)候,都無需直接訪問和,從而給開發(fā)者更多靈活的選擇??蓽y性方面的對(duì)比:測試的一個(gè)主要問題是方法依賴于,這使得的測試要依賴于容器。為了脫離容器測試的ct,必須借助于第三方擴(kuò)展:Stuteta該擴(kuò)展下包含了系列的c對(duì)象模擬了ttSeete和ettSelete對(duì)象n從而可以脫離e容器測試Stut的ct類。Stutct可以通過初始化、設(shè)置屬性、調(diào)用方法來測試。封裝請(qǐng)求參數(shù)的對(duì)比:Stut使用ct對(duì)象封裝用戶的請(qǐng)求參數(shù),所有的ct必須繼承一個(gè)基類:ct。普通的aa0不能用作ct,因此,開發(fā)者必須創(chuàng)建大量的ct類封裝用戶請(qǐng)求參數(shù)。雖然Stut提供了動(dòng)態(tài)ct來簡化ct的開發(fā),但依然需要在配置文件中定義ct;Stut直接使用ct屬性來封裝用戶請(qǐng)求屬性,避免了開發(fā)者需要大量開發(fā)ct類的煩瑣,實(shí)際上,這些屬性還可以是包含子屬性的對(duì)象類型。如果開發(fā)者依然懷念Stutct的模式,Stut提供el模式e可以讓開發(fā)者使用單獨(dú)的el對(duì)象來封裝用戶請(qǐng)求參數(shù),但該對(duì)象無需繼承任何Stut基類,是一個(gè),從而降低了代碼污染。表達(dá)式語言方面的對(duì)比:Stut整合了St因此可以使用S表達(dá)式語言。這種表達(dá)式語言有基本對(duì)象圖遍歷,但在對(duì)集合和索引屬性的支持上則功能不強(qiáng);Stut可以使用S,但它整合了一種更強(qiáng)大和靈活的表達(dá)式語言:(ectatataua,因此,Stut下的表達(dá)式語言功能更加強(qiáng)大。綁定值到視圖的對(duì)比:Stut使用標(biāo)準(zhǔn)S機(jī)制把對(duì)象綁定到視圖頁面;Stut使用“ValueStack”技術(shù),使標(biāo)簽庫能夠訪問值,而不需要把對(duì)象和視圖頁面綁定在一起。類型轉(zhuǎn)換的對(duì)比:Stutct屬性通常都是St類型。5=ut使用ce進(jìn)行類型轉(zhuǎn)換,每個(gè)類一個(gè)轉(zhuǎn)換器,轉(zhuǎn)換器是不可配置的;Stut使用進(jìn)行類型轉(zhuǎn)換,支持基本數(shù)據(jù)類型和常用對(duì)象之間的轉(zhuǎn)換。數(shù)據(jù)校驗(yàn)的對(duì)比:Stut支持在ct重寫al@方法中手動(dòng)校驗(yàn),或者通過整合框架來完成數(shù)據(jù)校驗(yàn)。Stut支持通過重寫alate法進(jìn)行校驗(yàn),也支持整合校驗(yàn)框架進(jìn)行校驗(yàn)。ct執(zhí)行控制的對(duì)比:Stut支持每一個(gè)模塊對(duì)應(yīng)一個(gè)請(qǐng)求處理(即生命周期的概念),但是模塊中的所有ct必須共享相同的生命周期。Stut支持通過攔截器堆棧(tecetStack)為每一個(gè)ct創(chuàng)建不同的生命周期。開發(fā)者可以根據(jù)需要?jiǎng)?chuàng)建相應(yīng)堆棧,從而和不同的ct一起使用。Stut的原理

初始化:置成自動(dòng)啟動(dòng)的框架的總控制器是一個(gè)初始化:置成自動(dòng)啟動(dòng)的框架的總控制器是一個(gè)v在啟動(dòng)時(shí)總控制器會(huì)讀取配置文件,它在中配的配置信息,為不同的模塊初始化相應(yīng)的對(duì)象。面向?qū)ο笏枷氚l(fā)送請(qǐng)求:用戶提交表單或通過向服務(wù)器提交請(qǐng)求,請(qǐng)求的數(shù)據(jù)用協(xié)議傳給服務(wù)器。填充:的總控制器在用戶提交請(qǐng)求時(shí)將數(shù)據(jù)放到對(duì)應(yīng)的對(duì)象中的成員變量中。派發(fā)請(qǐng)求:控制器根據(jù)配置信息對(duì)象將請(qǐng)求派發(fā)到具體的,對(duì)應(yīng)的一并傳給這個(gè)中的方法。處理業(yè)務(wù):一般只包含一個(gè)方法,它負(fù)責(zé)執(zhí)行相應(yīng)的業(yè)務(wù)邏輯調(diào)用其它的業(yè)務(wù)模塊完畢后返回一個(gè)對(duì)象。服務(wù)器通過對(duì)象進(jìn)行轉(zhuǎn)發(fā)工作。返回響應(yīng):將業(yè)務(wù)處理的不同結(jié)果返回一個(gè)目標(biāo)響應(yīng)對(duì)象給總控制器。查找響應(yīng):總控制器根據(jù)處理業(yè)務(wù)返回的目標(biāo)響應(yīng)對(duì)象,找到對(duì)應(yīng)的資源對(duì)象,一般情況下為頁面。響應(yīng)用戶:目標(biāo)響應(yīng)對(duì)象將結(jié)果傳遞給資源對(duì)象,將結(jié)果展現(xiàn)給用戶。的流程如何實(shí)現(xiàn)1根據(jù)輸入源不同,構(gòu)造不同的輸入流2根據(jù)不同的需要,包裝原始的輸入流。比如用提高性能。3根據(jù)輸出源不同,構(gòu)造不同的輸出流。4根據(jù)不同的需要,包裝原始的輸入流。5從輸入流中讀取數(shù)據(jù)寫入輸出流中。6關(guān)閉輸出,輸入流開發(fā)安全的注意要點(diǎn)i登陸驗(yàn)證碼。利用一個(gè)隨機(jī)產(chǎn)生一個(gè)驗(yàn)證碼,由于驗(yàn)證碼是機(jī)器隨機(jī)產(chǎn)生的,因此暴力破解程序無法預(yù)料到具體是什么,所以可以防止暴力破解。

2登陸身份驗(yàn)證。系統(tǒng)的每個(gè)功能都必須經(jīng)過身份驗(yàn)證后才能訪問,沒有認(rèn)證的請(qǐng)求會(huì)被過濾掉,這是最基本的安全要求:1所有功能都通過的來進(jìn)行訪問,不直接以的形式向用戶提供功能訪問,這樣一方面可以防止向用戶暴露程序的資源名稱,另一方面也可更方便的進(jìn)行權(quán)限控制。2對(duì)的設(shè)置,利用該來檢查用戶的權(quán)限,這樣既可以防止用戶登陸后跨訪問。3防止擾過權(quán)限認(rèn)證的直接資源訪問。雖然前面的設(shè)計(jì)中,已經(jīng)要求所有的功能都通過的來進(jìn)行訪問,但是還是不能排除惡意用戶可能會(huì)知道程序資源名稱(文件),如果這類用戶直接輸入文件的訪問,有可能會(huì)對(duì)系統(tǒng)形成威脅。因此需要禁止所有用戶發(fā)起的直接資源訪問。通常以這種方式來實(shí)現(xiàn):在應(yīng)用中創(chuàng)建一個(gè)從不使用的角色:,將所有的資源文件配置為必須具有才能訪問。由于根本沒有任何用戶可以成為該角色。由于根本沒有任何用戶可以成為該角色,所以也就無法對(duì)該角色對(duì)應(yīng)的資源直接訪問。常用的集合的區(qū)別接口是最基本的集合接口,一個(gè)代表一組,即的元素(e一些允許相同的元素而另一些不行。一些能排序而另一些不行。不提供直接繼承自的類,提供的類都是繼承自的“子接口”如和。接口是有序的,使用此接口能夠精確的控制每個(gè)元素插入的位置。用戶能夠使用索引(元素在中的位置,類似于數(shù)組下標(biāo))來訪問中的元素,這類似于的數(shù)組。和下面要提到的不同,允許有相同的元素。類實(shí)現(xiàn)了接口,允許元素。此外提供額外的,,方法在的首部或尾部。這些操作使可被用作堆棧()c隊(duì)列()或雙向隊(duì)列()u

隊(duì)列()或雙向隊(duì)列()u注意沒有同步方法。如果多個(gè)線程同時(shí)訪問一個(gè),則必須自己實(shí)現(xiàn)訪問同步。類實(shí)現(xiàn)了可變大小的數(shù)組。它允許所有元素,包括l沒有同步。zme方法運(yùn)行時(shí)間為常數(shù)。但是方法開銷為分?jǐn)偟某?shù),添加個(gè)元素需要的時(shí)間。其他的方法運(yùn)行時(shí)間為線性。當(dāng)需要插入大量元素時(shí),在插入前可以調(diào)用方法來增加的容量以提高插入效率。和一樣,也是非同步的(r類非常類似,但是是同步的。由創(chuàng)建的,雖然和創(chuàng)建的是同一接口,但是,因?yàn)槭峭降?,?dāng)一個(gè)被創(chuàng)建而且正在被使用,另一個(gè)線程改變了的狀態(tài)(例如,添加或刪除了一些元素),這時(shí)調(diào)用的方法時(shí)將拋出,因此必須捕獲該異常。類繼承自,實(shí)現(xiàn)一個(gè)后進(jìn)先出的堆棧。提供個(gè)額外的方法使得得以被當(dāng)作堆棧使用?;镜暮头椒?,還有方法得到棧頂?shù)脑兀椒y試堆棧是否為空,方法檢測一個(gè)元素在堆棧中的位置。剛創(chuàng)建后是空棧。接口是一種不包含重復(fù)的元素的,即任意的兩個(gè)元素和都有(最多有一個(gè)元素。接口請(qǐng)注意,沒有繼承接口,提供到的映射。一個(gè)中不能包含相同的,每個(gè)只能映射一個(gè)°接口提供種集合的視圖,的內(nèi)容可以被當(dāng)作一組集合,一組集合,或者一組映射。類繼承接口,實(shí)現(xiàn)一個(gè)映射的哈希表。任何非空()的對(duì)象都可作為或者的對(duì)象都可作為或者是同步的。類似,不同之處在于是非同步的,并且允許,即類似,不同之處在于是非同步的,并且允許,即和。,但是將視為時(shí)(方法可返回),其迭代子操作時(shí)間開銷和的容量成比例。因此,如果迭代操作的性能相當(dāng)重要的話,不要將的初始化容量設(shè)得過高,或者過低。的優(yōu)化)的優(yōu)化應(yīng)該放在優(yōu)先考慮,因?yàn)橐粋€(gè)在中發(fā)生比在中發(fā)生導(dǎo)致的成本更高)盡可能避免排序;盡可能在內(nèi)存中排序;分配合適的臨時(shí)空間以減少空間分配調(diào)用。)建立,但索引的層次越多,效率越低,索引所包含的字段不超過個(gè)。)表分區(qū))使用過濾行)使用表連接而不是多個(gè)查詢使用:而不是:)執(zhí)行連接時(shí)使用完全限定的列引用)使用表達(dá)式而不是多個(gè)查詢)使用而不用避免使用子句,只會(huì)在檢索出所有記錄之后才對(duì)結(jié)果集進(jìn)行過濾。這個(gè)處理需要排序,總計(jì)等操作。如果能通過子句限制記錄的數(shù)目,那就能減少這方面的開銷。0使用而不用)使用相同的,使用的必須絕對(duì)相同所有字符必須相同大小寫要相同所格要相同子句中的連接順序采用自下而上的順序解析子句,根據(jù)這個(gè)原理,表之間的連接必須寫在其他條件之前,那些可以過濾掉最大數(shù)量記錄的條件必須寫在子句的末尾。子句中避免使用‘*’例如:表包含個(gè)字段不用:*4使用函數(shù)來減少處理時(shí)間使用函數(shù)可以避免重復(fù)掃描相同記錄或重復(fù)連接相同的表。)減少對(duì)表的查詢?cè)诤凶硬樵兊恼Z句中,要特別注意減少對(duì)表的查詢。使用表的別名用替代在許多基于基礎(chǔ)表的查詢中,為了滿足一個(gè)條件,往往需要對(duì)另一個(gè)表進(jìn)行聯(lián)接。在這種情況下,使用或通常將提高查詢的效率。是怎么實(shí)現(xiàn)它先在中配置一個(gè),映射到特定的路徑(通常A這個(gè)的作用就是初始化要暴露給調(diào)用的類(通過進(jìn)行配置),并生成相應(yīng)的代理的類代碼。在請(qǐng)求到來的時(shí)候,負(fù)責(zé)將請(qǐng)求的參數(shù)變成對(duì)應(yīng)的對(duì)象,并以其為參數(shù)調(diào)用目標(biāo)方法,并將返回值轉(zhuǎn)化為代碼。和的區(qū)別接口是有序的,使用此接口能夠精確的控制每個(gè)元素插入的位置。用戶能夠使用索引(元素在中的位置,類似于數(shù)組下標(biāo))來訪問中的元素,這類似于的數(shù)組。和下面要提到的不同,允許有相同的元素。類實(shí)現(xiàn)了接口,允許元素。此外提供額外的,,方法在的首部或尾部。這些操作使可被用作堆棧()c隊(duì)列()或雙向隊(duì)列()u注意沒有同步方法。如果多個(gè)線程同時(shí)訪問一個(gè),則必須自己實(shí)現(xiàn)訪問同步。類實(shí)現(xiàn)了可變大小的數(shù)組。它允許所有元素,包括l沒有同步。zme方法運(yùn)行時(shí)間為常數(shù)。但是方法開銷為分?jǐn)偟某?shù),添加個(gè)元素需要的時(shí)間。其他的方法運(yùn)行時(shí)間為線性。當(dāng)需要插入大量元素時(shí),在插入前可以調(diào)用方法來增加的容量以提高插入效率。和一樣,也是非同步的(r類非常類似,但是是同步的。由創(chuàng)建的,雖然和創(chuàng)建的是同一接口,但是,因?yàn)槭峭降模?dāng)一個(gè)被創(chuàng)建而且正在被使用,另一個(gè)線程改變了的狀態(tài)(例如,添加或刪除了一些元素),這時(shí)調(diào)用的方法時(shí)將拋出,因此必須捕獲該異常。類繼承自,實(shí)現(xiàn)一個(gè)后進(jìn)先出的堆棧。提供個(gè)額外的方法使得得以被當(dāng)作堆棧使用?;镜暮头椒?,還有方

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(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)論