第一篇討論了面向?qū)ο缶幊毯退奶攸c,關(guān)于Java和它的功能的常見問題,Java的集合類,垃圾收集器,本章主要討論異常處理,Java小應(yīng)用程序,Swing,JDBC,遠程方法調(diào)用(RMI),Servlet和JSP。
異常處理
Java小應(yīng)用程序(Applet)
Swing
JDBC
遠程方法調(diào)用(RMI)
Servlet
JSP
異常處理
43.Java中的兩種異常類型是什么?他們有什么區(qū)別?
Java中有兩種異常:受檢查的(checked)異常和不受檢查的(unchecked)異常。不受檢查的異常不需要在方法或者是構(gòu)造函數(shù)上聲明,就算方法或者是構(gòu)造函數(shù)的執(zhí)行可能會拋出這樣的異常,并且不受檢查的異常可以傳播到方法或者是構(gòu)造函數(shù)的外面。相反,受檢查的異常必須要用throws語句在方法或者是構(gòu)造函數(shù)上聲明。這里有Java異常處理的一些小建議。
44.Java中Exception和Error有什么區(qū)別?
Exception和Error都是Throwable的子類。Exception用于用戶程序可以捕獲的異常情況。Error定義了不期望被用戶程序捕獲的異常。
45.throw和throws有什么區(qū)別?
throw關(guān)鍵字用來在程序中明確的拋出異常,相反,throws語句用來表明方法不能處理的異常。每一個方法都必須要指定哪些異常不能處理,所以方法的調(diào)用者才能夠確保處理可能發(fā)生的異常,多個異常是用逗號分隔的。
45.異常處理的時候,finally代碼塊的重要性是什么?(譯者注:作者標題的序號弄錯了)
無論是否拋出異常,finally代碼塊總是會被執(zhí)行。就算是沒有catch語句同時又拋出異常的情況下,finally代碼塊仍然會被執(zhí)行。最后要說的是,finally代碼塊主要用來釋放資源,比如:I/O緩沖區(qū),數(shù)據(jù)庫連接。
46.異常處理完成以后,Exception對象會發(fā)生什么變化?
Exception對象會在下一個垃圾回收過程中被回收掉。
47.finally代碼塊和finalize()方法有什么區(qū)別?
無論是否拋出異常,finally代碼塊都會執(zhí)行,它主要是用來釋放應(yīng)用占用的資源。finalize()方法是Object類的一個protected方法,它是在對象被垃圾回收之前由Java虛擬機來調(diào)用的。
Java小應(yīng)用程序(Applet)
48.什么是Applet?
java applet是能夠被包含在HTML頁面中并且能被啟用了java的客戶端瀏覽器執(zhí)行的程序。Applet主要用來創(chuàng)建動態(tài)交互的web應(yīng)用程序。
49.解釋一下Applet的生命周期
applet可以經(jīng)歷下面的狀態(tài):
- Init:每次被載入的時候都會被初始化。
- Start:開始執(zhí)行applet。
- Stop:結(jié)束執(zhí)行applet。
- Destroy:卸載applet之前,做最后的清理工作。
50.當applet被載入的時候會發(fā)生什么?
首先,創(chuàng)建applet控制類的實例,然后初始化applet,最后開始運行。
51.Applet和普通的Java應(yīng)用程序有什么區(qū)別?
applet是運行在啟用了java的瀏覽器中,Java應(yīng)用程序是可以在瀏覽器之外運行的獨立的Java程序。但是,它們都需要有Java虛擬機。
進一步來說,Java應(yīng)用程序需要一個有特定方法簽名的main函數(shù)來開始執(zhí)行。Java applet不需要這樣的函數(shù)來開始執(zhí)行。
最后,Java applet一般會使用很嚴格的安全策略,Java應(yīng)用一般使用比較寬松的安全策略。
52.Java applet有哪些限制條件?
主要是由于安全的原因,給applet施加了以下的限制:
- applet不能夠載入類庫或者定義本地方法。
- applet不能在宿主機上讀寫文件。
- applet不能讀取特定的系統(tǒng)屬性。
- applet不能發(fā)起網(wǎng)絡(luò)連接,除非是跟宿主機。
- applet不能夠開啟宿主機上其他任何的程序。
53.什么是不受信任的applet?
不受信任的applet是不能訪問或是執(zhí)行本地系統(tǒng)文件的Java applet,默認情況下,所有下載的applet都是不受信任的。
54.從網(wǎng)絡(luò)上加載的applet和從本地文件系統(tǒng)加載的applet有什么區(qū)別?
當applet是從網(wǎng)絡(luò)上加載的時候,applet是由applet類加載器載入的,它受applet安全管理器的限制。
當applet是從客戶端的本地磁盤載入的時候,applet是由文件系統(tǒng)加載器載入的。
從文件系統(tǒng)載入的applet允許在客戶端讀文件,寫文件,加載類庫,并且也允許執(zhí)行其他程序,但是,卻通不過字節(jié)碼校驗。
55.applet類加載器是什么?它會做哪些工作?
當applet是從網(wǎng)絡(luò)上加載的時候,它是由applet類加載器載入的。類加載器有自己的java名稱空間等級結(jié)構(gòu)。類加載器會保證來自文件系統(tǒng)的類有唯一的名稱空間,來自網(wǎng)絡(luò)資源的類有唯一的名稱空間。
當瀏覽器通過網(wǎng)絡(luò)載入applet的時候,applet的類被放置于和applet的源相關(guān)聯(lián)的私有的名稱空間中。然后,那些被類加載器載入進來的類都是通過了驗證器驗證的。驗證器會檢查類文件格式是否遵守Java語言規(guī)范,確保不會出現(xiàn)堆棧溢出(stack overflow)或者下溢(underflow),傳遞給字節(jié)碼指令的參數(shù)是正確的。
56.applet安全管理器是什么?它會做哪些工作?
applet安全管理器是給applet施加限制條件的一種機制。瀏覽器可以只有一個安全管理器。安全管理器在啟動的時候被創(chuàng)建,之后不能被替換覆蓋或者是擴展。
Swing
57.彈出式選擇菜單(Choice)和列表(List)有什么區(qū)別
Choice是以一種緊湊的形式展示的,需要下拉才能看到所有的選項。Choice中一次只能選中一個選項。List同時可以有多個元素可見,支持選中一個或者多個元素。
58.什么是布局管理器?
布局管理器用來在容器中組織組件。
59.滾動條(Scrollbar)和滾動面板(JScrollPane)有什么區(qū)別?
Scrollbar是一個組件,不是容器。而ScrollPane是容器。ScrollPane自己處理滾動事件。
60.哪些Swing的方法是線程安全的?
只有3個線程安全的方法: repaint(), revalidate(), and invalidate()。
61.說出三種支持重繪(painting)的組件。
Canvas, Frame, Panel,和Applet支持重繪。
62.什么是裁剪(clipping)?
限制在一個給定的區(qū)域或者形狀的繪圖操作就做裁剪。
63.MenuItem和CheckboxMenuItem的區(qū)別是什么?
CheckboxMenuItem類繼承自MenuItem類,支持菜單選項可以選中或者不選中。
64.邊緣布局(BorderLayout)里面的元素是如何布局的?
BorderLayout里面的元素是按照容器的東西南北中進行布局的。
65.網(wǎng)格包布局(GridBagLayout)里面的元素是如何布局的?
GridBagLayout里面的元素是按照網(wǎng)格進行布局的。不同大小的元素可能會占據(jù)網(wǎng)格的多于1行或一列。因此,行數(shù)和列數(shù)可以有不同的大小。
66.Window和Frame有什么區(qū)別?
Frame類繼承了Window類,它定義了一個可以有菜單欄的主應(yīng)用窗口。
67.裁剪(clipping)和重繪(repainting)有什么聯(lián)系?
當窗口被AWT重繪線程進行重繪的時候,它會把裁剪區(qū)域設(shè)置成需要重繪的窗口的區(qū)域。
68.事件監(jiān)聽器接口(event-listener interface)和事件適配器(event-adapter)有什么關(guān)系?
事件監(jiān)聽器接口定義了對特定的事件,事件處理器必須要實現(xiàn)的方法。事件適配器給事件監(jiān)聽器接口提供了默認的實現(xiàn)。
69.GUI組件如何來處理它自己的事件?
GUI組件可以處理它自己的事件,只要它實現(xiàn)相對應(yīng)的事件監(jiān)聽器接口,并且把自己作為事件監(jiān)聽器。
70.Java的布局管理器比傳統(tǒng)的窗口系統(tǒng)有哪些優(yōu)勢?
Java使用布局管理器以一種一致的方式在所有的窗口平臺上擺放組件。因為布局管理器不會和組件的絕對大小和位置相綁定,所以他們能夠適應(yīng)跨窗口系統(tǒng)的特定平臺的不同。
71.Java的Swing組件使用了哪種設(shè)計模式?
Java中的Swing組件使用了MVC(視圖-模型-控制器)設(shè)計模式。
JDBC
72.什么是JDBC?
JDBC是允許用戶在不同數(shù)據(jù)庫之間做選擇的一個抽象層。JDBC允許開發(fā)者用JAVA寫數(shù)據(jù)庫應(yīng)用程序,而不需要關(guān)心底層特定數(shù)據(jù)庫的細節(jié)。
73.解釋下驅(qū)動(Driver)在JDBC中的角色。
JDBC驅(qū)動提供了特定廠商對JDBC API接口類的實現(xiàn),驅(qū)動必須要提供java.sql包下面這些類的實現(xiàn):Connection, Statement, PreparedStatement,CallableStatement, ResultSet和Driver。
74.Class.forName()方法有什么作用?
這個方法用來載入跟數(shù)據(jù)庫建立連接的驅(qū)動。
75.PreparedStatement比Statement有什么優(yōu)勢?
PreparedStatements是預(yù)編譯的,因此,性能會更好。同時,不同的查詢參數(shù)值,PreparedStatement可以重用。
76.什么時候使用CallableStatement?用來準備CallableStatement的方法是什么?
CallableStatement用來執(zhí)行存儲過程。存儲過程是由數(shù)據(jù)庫存儲和提供的。存儲過程可以接受輸入?yún)?shù),也可以有返回結(jié)果。非常鼓勵使用存儲過程,因為它提供了安全性和模塊化。準備一個CallableStatement的方法是:
CallableStament.prepareCall();
77.數(shù)據(jù)庫連接池是什么意思?
像打開關(guān)閉數(shù)據(jù)庫連接這種和數(shù)據(jù)庫的交互可能是很費時的,尤其是當客戶端數(shù)量增加的時候,會消耗大量的資源,成本是非常高的。可以在應(yīng)用服務(wù)器啟動的時候建立很多個數(shù)據(jù)庫連接并維護在一個池中。連接請求由池中的連接提供。在連接使用完畢以后,把連接歸還到池中,以用于滿足將來更多的請求。
遠程方法調(diào)用(RMI)
78.什么是RMI?
Java遠程方法調(diào)用(Java RMI)是Java API對遠程過程調(diào)用(RPC)提供的面向?qū)ο蟮牡葍r形式,支持直接傳輸序列化的Java對象和分布式垃圾回收。遠程方法調(diào)用可以看做是激活遠程正在運行的對象上的方法的步驟。RMI對調(diào)用者是位置透明的,因為調(diào)用者感覺方法是執(zhí)行在本地運行的對象上的。看下RMI的一些注意事項。
79.RMI體系結(jié)構(gòu)的基本原則是什么?
RMI體系結(jié)構(gòu)是基于一個非常重要的行為定義和行為實現(xiàn)相分離的原則。RMI允許定義行為的代碼和實現(xiàn)行為的代碼相分離,并且運行在不同的JVM上。
80.RMI體系結(jié)構(gòu)分哪幾層?
RMI體系結(jié)構(gòu)分以下幾層:
存根和骨架層(Stub and Skeleton layer):這一層對程序員是透明的,它主要負責攔截客戶端發(fā)出的方法調(diào)用請求,然后把請求重定向給遠程的RMI服務(wù)。
遠程引用層(Remote Reference Layer):RMI體系結(jié)構(gòu)的第二層用來解析客戶端對服務(wù)端遠程對象的引用。這一層解析并管理客戶端對服務(wù)端遠程對象的引用。連接是點到點的。
傳輸層(Transport layer):這一層負責連接參與服務(wù)的兩個JVM。這一層是建立在網(wǎng)絡(luò)上機器間的TCP/IP連接之上的。它提供了基本的連接服務(wù),還有一些防火墻穿透策略。
81.RMI中的遠程接口(Remote Interface)扮演了什么樣的角色?
遠程接口用來標識哪些方法是可以被非本地虛擬機調(diào)用的接口。遠程對象必須要直接或者是間接實現(xiàn)遠程接口。實現(xiàn)了遠程接口的類應(yīng)該聲明被實現(xiàn)的遠程接口,給每一個遠程對象定義構(gòu)造函數(shù),給所有遠程接口的方法提供實現(xiàn)。
82.java.rmi.Naming類扮演了什么樣的角色?
java.rmi.Naming類用來存儲和獲取在遠程對象注冊表里面的遠程對象的引用。Naming類的每一個方法接收一個URL格式的String對象作為它的參數(shù)。
83.RMI的綁定(Binding)是什么意思?
綁定是為了查詢找遠程對象而給遠程對象關(guān)聯(lián)或者是注冊以后會用到的名稱的過程。遠程對象可以使用Naming類的bind()或者rebind()方法跟名稱相關(guān)聯(lián)。
84.Naming類的bind()和rebind()方法有什么區(qū)別?
bind()方法負責把指定名稱綁定給遠程對象,rebind()方法負責把指定名稱重新綁定到一個新的遠程對象。如果那個名稱已經(jīng)綁定過了,先前的綁定會被替換掉。
85.讓RMI程序能正確運行有哪些步驟?
為了讓RMI程序能正確運行必須要包含以下幾個步驟:
- 編譯所有的源文件。
- 使用rmic生成stub。
- 啟動rmiregistry。
- 啟動RMI服務(wù)器。
- 運行客戶端程序。
86.RMI的stub扮演了什么樣的角色?
遠程對象的stub扮演了遠程對象的代表或者代理的角色。調(diào)用者在本地stub上調(diào)用方法,它負責在遠程對象上執(zhí)行方法。當stub的方法被調(diào)用的時候,會經(jīng)歷以下幾個步驟:
- 初始化到包含了遠程對象的JVM的連接。
- 序列化參數(shù)到遠程的JVM。
- 等待方法調(diào)用和執(zhí)行的結(jié)果。
- 反序列化返回的值或者是方法沒有執(zhí)行成功情況下的異常。
- 把值返回給調(diào)用者。
87.什么是分布式垃圾回收(DGC)?它是如何工作的?
DGC叫做分布式垃圾回收。RMI使用DGC來做自動垃圾回收。因為RMI包含了跨虛擬機的遠程對象的引用,垃圾回收是很困難的。DGC使用引用計數(shù)算法來給遠程對象提供自動內(nèi)存管理。
88.RMI中使用RMI安全管理器(RMISecurityManager)的目的是什么?
RMISecurityManager使用下載好的代碼提供可被RMI應(yīng)用程序使用的安全管理器。如果沒有設(shè)置安全管理器,RMI的類加載器就不會從遠程下載任何的類。
89.解釋下Marshalling和demarshalling。
當應(yīng)用程序希望把內(nèi)存對象跨網(wǎng)絡(luò)傳遞到另一臺主機或者是持久化到存儲的時候,就必須要把對象在內(nèi)存里面的表示轉(zhuǎn)化成合適的格式。這個過程就叫做Marshalling,反之就是demarshalling。
90.解釋下Serialization和Deserialization。
Java提供了一種叫做對象序列化的機制,他把對象表示成一連串的字節(jié),里面包含了對象的數(shù)據(jù),對象的類型信息,對象內(nèi)部的數(shù)據(jù)的類型信息等等。因此,序列化可以看成是為了把對象存儲在磁盤上或者是從磁盤上讀出來并重建對象而把對象扁平化的一種方式。反序列化是把對象從扁平狀態(tài)轉(zhuǎn)化成活動對象的相反的步驟。
Servlet
91.什么是Servlet?
Servlet是用來處理客戶端請求并產(chǎn)生動態(tài)網(wǎng)頁內(nèi)容的Java類。Servlet主要是用來處理或者是存儲HTML表單提交的數(shù)據(jù),產(chǎn)生動態(tài)內(nèi)容,在無狀態(tài)的HTTP協(xié)議下管理狀態(tài)信息。
92.說一下Servlet的體系結(jié)構(gòu)。
所有的Servlet都必須要實現(xiàn)的核心的接口是javax.servlet.Servlet。每一個Servlet都必須要直接或者是間接實現(xiàn)這個接口,或者是繼承javax.servlet.GenericServlet或者javax.servlet.http.HTTPServlet。最后,Servlet使用多線程可以并行的為多個請求服務(wù)。
93.Applet和Servlet有什么區(qū)別?
Applet是運行在客戶端主機的瀏覽器上的客戶端Java程序。而Servlet是運行在web服務(wù)器上的服務(wù)端的組件。applet可以使用用戶界面類,而Servlet沒有用戶界面,相反,Servlet是等待客戶端的HTTP請求,然后為請求產(chǎn)生響應(yīng)。
94.GenericServlet和HttpServlet有什么區(qū)別?
GenericServlet是一個通用的協(xié)議無關(guān)的Servlet,它實現(xiàn)了Servlet和ServletConfig接口。繼承自GenericServlet的Servlet應(yīng)該要覆蓋service()方法。最后,為了開發(fā)一個能用在網(wǎng)頁上服務(wù)于使用HTTP協(xié)議請求的Servlet,你的Servlet必須要繼承自HttpServlet。這里有Servlet的例子。
95.解釋下Servlet的生命周期。
對每一個客戶端的請求,Servlet引擎載入Servlet,調(diào)用它的init()方法,完成Servlet的初始化。然后,Servlet對象通過為每一個請求單獨調(diào)用service()方法來處理所有隨后來自客戶端的請求,最后,調(diào)用Servlet(譯者注:這里應(yīng)該是Servlet而不是server)的destroy()方法把Servlet刪除掉。
96.doGet()方法和doPost()方法有什么區(qū)別?
doGet:GET方法會把名值對追加在請求的URL后面。因為URL對字符數(shù)目有限制,進而限制了用在客戶端請求的參數(shù)值的數(shù)目。并且請求中的參數(shù)值是可見的,因此,敏感信息不能用這種方式傳遞。
doPOST:POST方法通過把請求參數(shù)值放在請求體中來克服GET方法的限制,因此,可以發(fā)送的參數(shù)的數(shù)目是沒有限制的。最后,通過POST請求傳遞的敏感信息對外部客戶端是不可見的。
97.什么是Web應(yīng)用程序?
Web應(yīng)用程序是對Web或者是應(yīng)用服務(wù)器的動態(tài)擴展。有兩種類型的Web應(yīng)用:面向表現(xiàn)的和面向服務(wù)的。面向表現(xiàn)的Web應(yīng)用程序會產(chǎn)生包含了很多種標記語言和動態(tài)內(nèi)容的交互的web頁面作為對請求的響應(yīng)。而面向服務(wù)的Web應(yīng)用實現(xiàn)了Web服務(wù)的端點(endpoint)。一般來說,一個Web應(yīng)用可以看成是一組安裝在服務(wù)器URL名稱空間的特定子集下面的Servlet的集合。
98.什么是服務(wù)端包含(Server Side Include)?
服務(wù)端包含(SSI)是一種簡單的解釋型服務(wù)端腳本語言,大多數(shù)時候僅用在Web上,用servlet標簽嵌入進來。SSI最常用的場景把一個或多個文件包含到Web服務(wù)器的一個Web頁面中。當瀏覽器訪問Web頁面的時候,Web服務(wù)器會用對應(yīng)的servlet產(chǎn)生的文本來替換Web頁面中的servlet標簽。
99.什么是Servlet鏈(Servlet Chaining)?
Servlet鏈是把一個Servlet的輸出發(fā)送給另一個Servlet的方法。第二個Servlet的輸出可以發(fā)送給第三個Servlet,依次類推。鏈條上最后一個Servlet負責把響應(yīng)發(fā)送給客戶端。
100.如何知道是哪一個客戶端的機器正在請求你的Servlet?
ServletRequest類可以找出客戶端機器的IP地址或者是主機名。getRemoteAddr()方法獲取客戶端主機的IP地址,getRemoteHost()可以獲取主機名。看下這里的例子。
101.HTTP響應(yīng)的結(jié)構(gòu)是怎么樣的?
HTTP響應(yīng)由三個部分組成:
狀態(tài)碼(Status Code):描述了響應(yīng)的狀態(tài)。可以用來檢查是否成功的完成了請求。請求失敗的情況下,狀態(tài)碼可用來找出失敗的原因。如果Servlet沒有返回狀態(tài)碼,默認會返回成功的狀態(tài)碼HttpServletResponse.SC_OK。
HTTP頭部(HTTP Header):它們包含了更多關(guān)于響應(yīng)的信息。比如:頭部可以指定認為響應(yīng)過期的過期日期,或者是指定用來給用戶安全的傳輸實體內(nèi)容的編碼格式。如何在Serlet中檢索HTTP的頭部看這里。
主體(Body):它包含了響應(yīng)的內(nèi)容。它可以包含HTML代碼,圖片,等等。主體是由傳輸在HTTP消息中緊跟在頭部后面的數(shù)據(jù)字節(jié)組成的。
102.什么是cookie?session和cookie有什么區(qū)別?
cookie是Web服務(wù)器發(fā)送給瀏覽器的一塊信息。瀏覽器會在本地文件中給每一個Web服務(wù)器存儲cookie。以后瀏覽器在給特定的Web服務(wù)器發(fā)請求的時候,同時會發(fā)送所有為該服務(wù)器存儲的cookie。下面列出了session和cookie的區(qū)別:
無論客戶端瀏覽器做怎么樣的設(shè)置,session都應(yīng)該能正常工作。客戶端可以選擇禁用cookie,但是,session仍然是能夠工作的,因為客戶端無法禁用服務(wù)端的session。
在存儲的數(shù)據(jù)量方面session和cookies也是不一樣的。session能夠存儲任意的Java對象,cookie只能存儲String類型的對象。
103.瀏覽器和Servlet通信使用的是什么協(xié)議?
瀏覽器和Servlet通信使用的是HTTP協(xié)議。
104.什么是HTTP隧道?
HTTP隧道是一種利用HTTP或者是HTTPS把多種網(wǎng)絡(luò)協(xié)議封裝起來進行通信的技術(shù)。因此,HTTP協(xié)議扮演了一個打通用于通信的網(wǎng)絡(luò)協(xié)議的管道的包裝器的角色。把其他協(xié)議的請求掩蓋成HTTP的請求就是HTTP隧道。
105.sendRedirect()和forward()方法有什么區(qū)別?
sendRedirect()方法會創(chuàng)建一個新的請求,而forward()方法只是把請求轉(zhuǎn)發(fā)到一個新的目標上。重定向(redirect)以后,之前請求作用域范圍以內(nèi)的對象就失效了,因為會產(chǎn)生一個新的請求,而轉(zhuǎn)發(fā)(forwarding)以后,之前請求作用域范圍以內(nèi)的對象還是能訪問的。一般認為sendRedirect()比forward()要慢。
106.什么是URL編碼和URL解碼?
URL編碼是負責把URL里面的空格和其他的特殊字符替換成對應(yīng)的十六進制表示,反之就是解碼。
JSP
107.什么是JSP頁面?
JSP頁面是一種包含了靜態(tài)數(shù)據(jù)和JSP元素兩種類型的文本的文本文檔。靜態(tài)數(shù)據(jù)可以用任何基于文本的格式來表示,比如:HTML或者XML。JSP是一種混合了靜態(tài)內(nèi)容和動態(tài)產(chǎn)生的內(nèi)容的技術(shù)。這里看下JSP的例子。
108.JSP請求是如何被處理的?
瀏覽器首先要請求一個以.jsp擴展名結(jié)尾的頁面,發(fā)起JSP請求,然后,Web服務(wù)器讀取這個請求,使用JSP編譯器把JSP頁面轉(zhuǎn)化成一個Servlet類。需要注意的是,只有當?shù)谝淮握埱箜撁婊蛘呤荍SP文件發(fā)生改變的時候JSP文件才會被編譯,然后服務(wù)器調(diào)用servlet類,處理瀏覽器的請求。一旦請求執(zhí)行結(jié)束,servlet會把響應(yīng)發(fā)送給客戶端。這里看下如何在JSP中獲取請求參數(shù)。
109.JSP有什么優(yōu)點?
下面列出了使用JSP的優(yōu)點:
- JSP頁面是被動態(tài)編譯成Servlet的,因此,開發(fā)者可以很容易的更新展現(xiàn)代碼。
- JSP頁面可以被預(yù)編譯。
- JSP頁面可以很容易的和靜態(tài)模板結(jié)合,包括:HTML或者XML,也可以很容易的和產(chǎn)生動態(tài)內(nèi)容的代碼結(jié)合起來。
- 開發(fā)者可以提供讓頁面設(shè)計者以類XML格式來訪問的自定義的JSP標簽庫。
- 開發(fā)者可以在組件層做邏輯上的改變,而不需要編輯單獨使用了應(yīng)用層邏輯的頁面。
110.什么是JSP指令(Directive)?JSP中有哪些不同類型的指令?
Directive是當JSP頁面被編譯成Servlet的時候,JSP引擎要處理的指令。Directive用來設(shè)置頁面級別的指令,從外部文件插入數(shù)據(jù),指定自定義的標簽庫。Directive是定義在<%@ 和 %>之間的。下面列出了不同類型的Directive:
包含指令(Include directive):用來包含文件和合并文件內(nèi)容到當前的頁面。
頁面指令(Page directive):用來定義JSP頁面中特定的屬性,比如錯誤頁面和緩沖區(qū)。
Taglib指令: 用來聲明頁面中使用的自定義的標簽庫。
111.什么是JSP動作(JSP action)?
JSP動作以XML語法的結(jié)構(gòu)來控制Servlet引擎的行為。當JSP頁面被請求的時候,JSP動作會被執(zhí)行。它們可以被動態(tài)的插入到文件中,重用JavaBean組件,轉(zhuǎn)發(fā)用戶到其他的頁面,或者是給Java插件產(chǎn)生HTML代碼。下面列出了可用的動作:
- jsp:include-當JSP頁面被請求的時候包含一個文件。
- jsp:useBean-找出或者是初始化Javabean。
- jsp:setProperty-設(shè)置JavaBean的屬性。
- jsp:getProperty-獲取JavaBean的屬性。
- jsp:forward-把請求轉(zhuǎn)發(fā)到新的頁面。
- jsp:plugin-產(chǎn)生特定瀏覽器的代碼。
112.什么是Scriptlets?
JSP技術(shù)中,scriptlet是嵌入在JSP頁面中的一段Java代碼。scriptlet是位于標簽內(nèi)部的所有的東西,在標簽與標簽之間,用戶可以添加任意有效的scriplet。
113.聲明(Decalaration)在哪里?
聲明跟Java中的變量聲明很相似,它用來聲明隨后要被表達式或者scriptlet使用的變量。添加的聲明必須要用開始和結(jié)束標簽包起來。
114.什么是表達式(Expression)?
【列表很長,可以分上、中、下發(fā)布】
JSP表達式是Web服務(wù)器把腳本語言表達式的值轉(zhuǎn)化成一個String對象,插入到返回給客戶端的數(shù)據(jù)流中。表達式是在<%=和%>這兩個標簽之間定義的。
115.隱含對象是什么意思?有哪些隱含對象?
JSP隱含對象是頁面中的一些Java對象,JSP容器讓這些Java對象可以為開發(fā)者所使用。開發(fā)者不用明確的聲明就可以直接使用他們。JSP隱含對象也叫做預(yù)定義變量。下面列出了JSP頁面中的隱含對象:
- application
- page
- request
- response
- session
- exception
- out
- config
- pageContext
以上就是對Java 面試題的資料整理,謝謝大家對本站的支持!