共享一些面試題

題目如下:(不妨先做下試試,看自己水平如何,然後再看下面的答案.)

01.通過什麼參數分配Java內存使用?
02.Treemap和Hashmap區別是什麼?
03.爲何加入:private static final long serialVersionUID??
04.JSP編譯和執行原理?
05.怎麼解決JSP/Servlet web中中文亂碼的問題
06.JDBC中,statement,prepared statement ,Callable statement的區別是什麼?
07.什麼情況下會拋出“打開遊標超過最大數”的異常?
08.XML解析中:SAX和DOM的不同點有哪些?
09.抽象類和接口的區別?
10.什麼是中間件
11.JSP的內置對象有那些?
12.有那些方法能防止、化解對web網站的攻擊?
13.如何提高訪問web網站的速度?
14.Java可採用的MVC框架技術有哪些?他們的特徵和適用環境如何?
15.MVC的優缺點是什麼,適用範圍如何?
16.TOMCAT配置中,有關安全的設置選項有哪些?
17.Apach與Tomcat配合使用,是爲解決什麼問題?怎麼實現?運行過程如何?
18.Collection的四個接口
19.Cookie
20.多態
21.Web上參數的傳輸方式
22.HashTable和HashMap的區別
23.運行環境中的GC
24.final,finally,finalzie的區別
25.Session
26.編程實現多線程:記錄各自的時間。

答案如下:

1.通過什麼參數分配Java內存使用?
java -Xms128m -Xmx512m

2.Treemap和Hashmap區別是什麼?
TreeMap對Key進行排序,而HashMap不排序。HashMap通過hashcode對其內容進行快速查找, 而TreeMap中所有的元素都保持着某種固定的順序,如果你需要得到一個有序的結果你就應該 使用TreeMap(HashMap中元素的排列順序是不固定的)。

3.爲何加入:private static final long serialVersionUID?
可以利用JDK的bin目錄下的serialver.exe工具產生。
序列化時爲了保持版本的兼容性,即在版本升級時反序列化仍保持 對象的唯一性。在java中serialVersionUID是唯一控制着能否反序列化成功的標誌, 只要這個值不一樣,就無法反序列化成功。

4.JSP編譯和執行原理?
JSP文件的Scriptlets在編譯後將被包含於該JSP servlet的service()方法。當JSP引擎處理客戶端請求時,JSP Scriptlets在被請求的時候被執行。如果scriptlet產生輸出,輸出將在out (JSPWriter)對象中進行緩存然後最終發送到客戶端。

5.怎麼解決JSP/Servlet web中中文亂碼的問題

6.JDBC中,statement,prepared statement ,Callable statement的區別是什麼?
Statement 接口提供了執行語句和獲取結果的基本方法。PreparedStatement 接口添加了處理 IN 參數的方法;而 CallableStatement 添加了處理 OUT 參數的方法。
PreparedStatement:對於同一條語句的多次執行,Statement每次都要把SQL語句發送給數據
庫,這樣做效率明顯不高,而如果數據庫支持預編譯,PreparedStatement可以先把要執行的語句一次發給它,然後每次執行而不必發送相同的語句,效率當然提高,當然如果數據庫不支持預編譯,
PreparedStatement會象Statement一樣工作,只是效率不高而不需要用戶工手干預.
    另外PreparedStatement還支持接收參數.在預編譯後只要傳輸不同的參數就可以執行,大大
提高了性能.
CallableStatement:是PreparedStatement的子類,它只是用來執行存儲過程的.

7.什麼情況下會拋出“打開遊標超過最大數”的異常?

8.XML解析中:SAX和DOM的不同點有哪些?

9.抽象類和接口的區別?

10.什麼是中間件

11.JSP的內置對象有那些?
Out, request, response, application, session, exception, config, page, pageContext.

12.有那些方法能防止、化解對web網站的攻擊?
13.如何提高訪問web網站的速度?
14.Java可採用的MVC框架技術有哪些?他們的特徵和適用環境如何?
Struts, WebWork, Spring, JSF…

15.MVC的優缺點是什麼,適用範圍如何?
MVC開發模式分離數據訪問層和數據表現層,並使開發人員開發一個可伸縮性的強、便於擴展的控制器,來維護整個流程。
16.TOMCAT配置中,有關安全的設置選項有哪些?
17.Apach與Tomcat配合使用,是爲解決什麼問題?怎麼實現?運行過程如何?


18.Collection的四個接口
add();
addAll();
isEmpty();
iterator();
contains();

19.Cookie
20.多態
21.Web上參數的傳輸方式
22.HashTable和HashMap的區別
Hashtable和HashMap類有三個重要的不同之處。第一個不同主要是歷史原因。Hashtable是基於陳舊的Dictionary類的,HashMap是Java 1.2引進的Map接口的一個實現。 
也許最重要的不同是Hashtable的方法是同步的,而HashMap的方法不是。這就意味着,雖然你可以不用採取任何特殊的行爲就可以在一個多線程的應用程序中用一個Hashtable,但你必須同樣地爲一個HashMap提供外同步。一個方便的方法就是利用Collections類的靜態的synchronizedMap()方法,它創建一個線程安全的Map對象,並把它作爲一個封裝的對象來返回。這個對象的方法可以讓你同步訪問潛在的HashMap。這麼做的結果就是當你不需要同步時,你不能切斷Hashtable中的同步(比如在一個單線程的應用程序中),而且同步增加了很多處理費用。 
第三點不同是,只有HashMap可以讓你將空值作爲一個表的條目的key或value。HashMap中只有一條記錄可以是一個空的key,但任意數量的條目可以是空的value。這就是說,如果在表中沒有發現搜索鍵,或者如果發現了搜索鍵,但它是一個空的值,那麼get()將返回null。如果有必要,用containKey()方法來區別這兩種情況。
23.運行環境中的GC

24.final,finally,finalzie的區別
final:
final可以讓你控制你的成員、方法或者是一個類是否可被覆寫或繼承等功能,這些特點使final在Java中擁有了一個不可或缺的地位,也是學習Java時必須要知道和掌握的關鍵字之一。
final成員
當你在類中定義變量時,在其前面加上final關鍵字,那便是說,這個變量一旦被初始化便不可改變,這裏不可改變的意思對基本類型來說是其值不可變,而對於對象變量來說其引用不可再變。其初始化可以在兩個地方,一是其定義處,二是在構造函數中,兩者只能選其一。
還有一種用法是定義方法中的參數爲final,對於基本類型的變量,這樣做並沒有什麼實際意義,因爲基本類型的變量在調用方法時是傳值的,也就是說你可以在方法中更改這個參數變量而不會影響到調用語句,然而對於對象變量,卻顯得很實用,因爲對象變量在傳遞時是傳遞其引用,這樣你在方法中對對象變量的修改也會影響到調用語句中的對象變量,當你在方法中不需要改變作爲參數的對象變量時,明確使用final進行聲明,會防止你無意的修改而影響到調用方法。
final方法
將方法聲明爲final那有兩個原因,第一就是說明你已經知道這個方法提供的功能已經滿足你要求,不需要進行擴展,並且也不允許任何從此類繼承的類來覆寫這個方法,但是繼承仍然可以繼承這個方法,也就是說可以直接使用。第二就是允許編譯器將所有對此方法的調用轉化爲inline(行內)調用的機制,它會使你在調用final方法時,直接將方法主體插入到調用處,而不是進行例行的方法調用,例如保存斷點,壓棧等,這樣可能會使你的程序效率有所提高,然而當你的方法主體非常龐大時,或你在多處調用此方法,那麼你的調用主體代碼便會迅速膨脹,可能反而會影響效率,所以你要慎用final進行方法定義。
final類
當你將final用於類身上時,你就需要仔細考慮,因爲一個final類是無法被任何人繼承的,那也就意味着此類在一個繼承樹中是一個葉子類,並且此類的設計已被認爲很完美而不需要進行修改或擴展。對於final類中的成員,你可以定義其爲final,也可以不是final。而對於方法,由於所屬類爲final的關係,自然也就成了final型的。你也可以明確的給final類中的方法加上一個final,但這顯然沒有意義。

finally:
finally 關鍵字是對 Java 異常處理模型的最佳補充。 finally 結構使代碼總會執行,而不管有無異常發生。使用 finally 可以維護對象的內部狀態,並可以清理非內存資源。如果沒有 finally,您的代碼就會很費解。例如,下面的代碼說明,在不使用 finally 的情況下您如何編寫代碼來釋放非內存資源:

finalize: 
根據Java語言規範,JVM保證調用finalize函數之前,這個對象是不可達的,但是JVM不保證這個函數一定會被調用。另外,規範還保證finalize函數最多運行一次。
通常,finalize用於一些不容易控制、並且非常重要資源的釋放,例如一些I/O的操作,數據的連接。這些資源的釋放對整個應用程序是非常關鍵的。在這種情況下,程序員應該以通過程序本身管理(包括釋放)這些資源爲主,以finalize函數釋放資源方式爲輔,形成一種雙保險的管理機制,而不應該僅僅依靠finalize來釋放資源。

 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章