-
1 # 玩著學程式設計
-
2 # 網際網路IT資訊
同時,這裡每天都會發布技術文章,不但讓自己知道如何做面試題,還真正瞭解技術,在最終的一對一的面試中,也能有幫助,下邊列舉其中一部分文章,不如:
京東和騰訊精選12道Java筆試題並有答案
Java:重入鎖ReentranLock詳解、程式碼實戰、與Synchronized對比
Java:XML基本語法、DOM、SAX、JDOM、DOM4J綜合對比和程式碼實戰
Java網路程式設計:TCP和UDP通訊模型詳解及基於程式碼實戰的通訊程式設計
Java併發程式設計:基於程式碼實戰的4種執行緒池和緩衝佇列BlockingQueue
-
3 # 千鋒武漢
關於贏在面試的Java題系列基本收集整理完成了,所有題目都是經過精心挑選的,很基礎又考驗求職者的基本功,應該說被面試到的機率很大。這裡整理挑選出來供大家面試前拿來看一看。
1、a.hashCode() 有什麼用?與 a.equals(b) 有什麼關係?hashCode() 方法對應物件整型的 hash 值。它常用於基於 hash 的集合類,如 Hashtable、HashMap、LinkedHashMap等等。它與 equals() 方法關係特別緊密。根據 Java 規範,兩個使用 equal() 方法來判斷相等的物件,必須具有相同的 hash code。
2、位元組流與字元流的區別要把一段二進位制資料資料逐一輸出到某個裝置中,或者從某個裝置中逐一讀取一段二進位制資料,不管輸入輸出裝置是什麼,我們要用統一的方式來完成這些操作,用一種抽象的方式進行描述,這個抽象描述方式起名為IO流,對應的抽象類為OutputStream和InputStream,不同的實現類就代表不同的輸入和輸出裝置,它們都是針對位元組進行操作的。
計算機中的一切最終都是二進位制的位元組形式存在。對於經常用到的中文字元,首先要得到其對應的位元組,然後將位元組寫入到輸出流。讀取時,首先讀到的是位元組,可是我們要把它顯示為字元,我們需要將位元組轉換成字元。由於這樣的需求很廣泛,Java專門提供了字元流包裝類。
底層裝置永遠只接受位元組資料,有時候要寫字串到底層裝置,需要將字串轉成位元組再進行寫入。字元流是位元組流的包裝,字元流則是直接接受字串,它內部將串轉成位元組,再寫入底層裝置,這為我們向IO裝置寫入或讀取字串提供了一點點方便。
字元向位元組轉換時,要注意編碼的問題,因為字串轉成位元組陣列,其實是轉成該字元的某種編碼的位元組形式,讀取也是反之的道理。
3、什麼是Java序列化,如何實現Java序列化?或者請解釋Serializable介面的作用。我們有時候將一個Java物件變成位元組流的形式傳出去或者從一個位元組流中恢復成一個Java物件,例如,要將Java物件儲存到硬碟或者傳送給網路上的其他計算機,這個過程我們可以自己寫程式碼去把一個Java物件變成某個格式的位元組流再傳輸。
但是,jre本身就提供了這種支援,我們可以呼叫OutputStream的writeObject方法來做,如果要讓Java幫我們做,要被傳輸的物件必須實現serializable介面,這樣,Javac編譯時就會進行特殊處理,編譯的類才可以被writeObject方法操作,這就是所謂的序列化。需要被序列化的類必須實現Serializable介面,該介面是一個mini介面,其中沒有需要實現方法,implements Serializable只是為了標註該物件是可被序列化的。
例如,在web開發中,如果物件被儲存在了Session中,tomcat在重啟時要把Session物件序列化到硬碟,這個物件就必須實現Serializable介面。如果物件要經過分散式系統進行網路傳輸,被傳輸的物件就必須實現Serializable介面。
4、描述一下JVM載入class檔案的原理機制?JVM中類的裝載是由ClassLoader和它的子類來實現的,Java ClassLoader是一個重要的Java執行時系統元件。它負責在執行時查詢和裝入類檔案的類。
5、heap和stack有什麼區別。Java的記憶體分為兩類,一類是棧記憶體,一類是堆記憶體。棧記憶體是指程式進入一個方法時,會為這個方法單獨分配一塊私屬儲存空間,用於儲存這個方法內部的區域性變數,當這個方法結束時,分配給這個方法的棧會釋放,這個棧中的變數也將隨之釋放。
堆是與棧作用不同的記憶體,一般用於存放不在當前方法棧中的那些資料,例如,使用new建立的物件都放在堆裡,所以,它不會隨方法的結束而消失。方法中的區域性變數使用final修飾後,放在堆中,而不是棧中。
6、GC是什麼?為什麼要有GC?GC是垃圾收集的意思(Gabage Collection),記憶體處理是程式設計人員容易出現問題的地方,忘記或者錯誤的記憶體回收會導致程式或系統的不穩定甚至崩潰,Java提供的GC功能可以自動監測物件是否超過作用域從而達到自動回收記憶體的目的,Java語言沒有提供釋放已分配記憶體的顯示操作方法。
7、垃圾回收的優點和原理。並考慮2種回收機制。Java語言中一個顯著的特點就是引入了垃圾回收機制,使c++程式設計師最頭疼的記憶體管理的問題迎刃而解,它使得Java程式設計師在編寫程式的時候不再需要考慮記憶體管理。由於垃圾回收機制,Java中的物件不再有"作用域"的概念,只有物件的引用才有"作用域"。
垃圾回收可以有效的防止記憶體洩露,有效的使用可以使用的記憶體。垃圾回收器通常是作為一個單獨的低級別的執行緒執行,不可預知的情況下對記憶體堆中已經死亡的或者長時間沒有使用的物件進行清除和回收,程式設計師不能實時的呼叫垃圾回收器對某個物件或所有物件進行垃圾回收。
回收機制有分代複製垃圾回收和標記垃圾回收,增量垃圾回收。
8、垃圾回收器的基本原理是什麼?垃圾回收器可以馬上回收記憶體嗎?有什麼辦法主動通知虛擬機器進行垃圾回收?對於GC來說,當程式設計師建立物件時,GC就開始監控這個物件的地址、大小以及使用情況。通常,GC採用有向圖的方式記錄和管理堆(heap)中的所有物件。透過這種方式確定哪些物件是"可達的",哪些物件是"不可達的"。當GC確定一些物件為"不可達"時,GC就有責任回收這些記憶體空間。
程式設計師可以手動執行System.gc(),通知GC執行,但是Java語言規範並不保證GC一定會執行。
9、Java中throw和throws有什麼區別?throw 用於丟擲 Java.lang.Throwable 類的一個例項化物件,意思是說你可以透過關鍵字 throw 丟擲一個Exception,如:
throw new IllegalArgumentException(“XXXXXXXXX″)
而throws 的作用是作為方法宣告和簽名的一部分,方法被丟擲相應的異常以便呼叫者能處理。Java 中,任何未處理的受檢查異常強制在 throws 子句中宣告。
10、Java中會存在記憶體洩漏嗎,請簡單描述。先解釋什麼是記憶體洩漏:所謂記憶體洩露就是指一個不再被程式使用的物件或變數一直被佔據在記憶體中。Java中有垃圾回收機制,它可以保證當物件不再被引用的時候,物件將自動被垃圾回收器從記憶體中清除掉。
由於Java使用有向圖的方式進行垃圾回收管理,可以消除引用迴圈的問題,例如有兩個物件,相互引用,只要它們和根程序不可達,那麼GC也是可以回收它們的。
Java中的記憶體洩露的情況:長生命週期的物件持有短生命週期物件的引用就很可能發生記憶體洩露,儘管短生命週期物件已經不再需要,但是因為長生命週期物件持有它的引用而導致不能被回收,這就是Java中記憶體洩露的發生場景,通俗地說,就是程式設計師可能建立了一個物件,以後一直不再使用這個物件,這個物件卻一直被引用,即這個物件無用但是卻無法被垃圾回收器回收的,這就是Java中可能出現記憶體洩露的情況,例如,快取系統,我們載入了一個物件放在快取中(例如放在一個全域性map物件中),然後一直不再使用它,這個物件一直被快取引用,但卻不再被使用。
11 、說一說Servlet的生命週期?Servlet有良好的生存期的定義,包括載入和例項化、初始化、處理請求以及服務結束。這個生存期由Javax.servlet.Servlet介面的init(),service()和destroy方法表達。
Servlet被伺服器例項化後,容器執行其init方法,請求到達時執行其service方法,service方法自動派遣執行與請求對應的doXXX方法(doGet,doPost)等,當伺服器決定將例項銷燬的時候呼叫其destroy方法。
web容器載入servlet,生命週期開始。透過呼叫servlet的init()方法進行servlet的初始化。透過呼叫service()方法實現,根據請求的不同調用不同的do***()方法。結束服務,web容器呼叫servlet的destroy()方法。
12、Servlet API中forward()與redirect()的區別?(1).從位址列顯示來說
forward是伺服器請求資源,伺服器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,然後把這些內容再發給瀏覽器.瀏覽器根本不知道伺服器傳送的內容從哪裡來的,所以它的位址列還是原來的地址.
redirect是服務端根據邏輯,傳送一個狀態碼,告訴瀏覽器重新去請求那個地址.所以位址列顯示的是新的URL.所以redirect等於客戶端向伺服器端發出兩次request,同時也接受兩次response。
(2).從資料共享來說
redirect:不能共享資料.
redirect不僅可以重定向到當前應用程式的其他資源,還可以重定向到同一個站點上的其他應用程式中的資源,甚至是使用絕對URL重定向到其他站點的資源.
redirect 是伺服器通知客戶端,讓客戶端重新發起請求.
所以,你可以說 redirect 是一種間接的請求, 但是你不能說"一個請求是屬於forward還是redirect "
(3).從運用地方來說
redirect:一般用於使用者登出登陸時返回主頁面和跳轉到其它的網站等.
(4).從效率來說
forward:高.
redirect:低.
13、request.getAttribute()和 request.getParameter()有何區別?(1),request.getParameter()取得是透過容器的實現來取得透過類似post,get等方式傳入的資料。
request.setAttribute()和getAttribute()只是在web容器內部流轉,僅僅是請求處理階段。
(2),getAttribute是返回物件,getParameter返回字串
(3),getAttribute()一向是和setAttribute()一起使用的,只有先用setAttribute()設定之後,才能夠透過getAttribute()來獲得值,它們傳遞的是Object型別的資料。而且必須在同一個request物件中使用才有效。,而getParameter()是接收表單的get或者post提交過來的引數
14、jsp靜態包含和動態包含的區別(1)、<%@include file="xxx.jsp"%>為jsp中的編譯指令,其檔案的包含是發生在jsp向servlet轉換的時期,而<jsp:include page="xxx.jsp">是jsp中的動作指令,其檔案的包含是發生在編譯時期,也就是將Java檔案編譯為class檔案的時期
(2)、使用靜態包含只會產生一個class檔案,而使用動態包含會產生多個class檔案
(3)、使用靜態包含,包含頁面和被包含頁面的request物件為同一物件,因為靜態包含只是將被包含的頁面的內容複製到包含的頁面中去;而動態包含包含頁面和被包含頁面不是同一個頁面,被包含的頁面的request物件可以取到的引數範圍要相對大些,不僅可以取到傳遞到包含頁面的引數,同樣也能取得在包含頁面向下傳遞的引數。
15 、MVC的各個部分都有那些技術來實現?如何實現?MVC是Model-View-Controller的簡寫。Model代表的是應用的業務邏輯(透過JavaBean,EJB元件實現),View是應用的表示面(由JSP頁面產生),Controller是提供應用的處理過程控制(一般是一個Servlet),透過這種設計模型把應用邏輯,處理過程和顯示邏輯分成不同的元件實現。這些元件可以進行互動和重用。
16、jsp有哪些內建物件?作用分別是什麼?JSP共有以下9個內建的物件:
(1),request 使用者端請求,此請求會包含來自GET/POST請求的引數
(2),response 網頁傳回使用者端的迴應
(3),pageContext 網頁的屬性是在這裡管理
(4),session 與請求有關的會話期
(5),application servlet 正在執行的內容
(6),out 用來傳送回應的輸出
(7),config servlet的構架部件
(8),page JSP網頁本身
(9),exception 針對錯誤網頁,未捕捉的例外
17 、Http中,get和post方法的區別(1),Get是向伺服器發索取資料的一種請求,而Post是向伺服器提交資料的一種請求
(2),Get是獲取資訊,而不是修改資訊,類似資料庫查詢功能一樣,資料不會被修改
(3),Get請求的引數會跟在url後進行傳遞,請求的資料會附在URL之後,以?分割URL和傳輸資料,引數之間以&相連,%XX中的XX為該符號以16進製表示的ASCII,如果資料是英文字母/數字,原樣傳送,如果是空格,轉換為+,如果是中文/其他字元,則直接把字串用BASE64加密。
(4),Get傳輸的資料有大小限制,因為GET是透過URL提交資料,那麼GET可提交的資料量就跟URL的長度有直接關係了,不同的瀏覽器對URL的長度的限制是不同的。
(5),GET請求的資料會被瀏覽器快取起來,使用者名稱和密碼將明文出現在URL上,其他人可以查到歷史瀏覽記錄,資料不太安全。
在伺服器端,用Request.QueryString來獲取Get方式提交來的資料Post請求則作為http訊息的實際內容傳送給web伺服器,資料放置在HTML Header內提交,Post沒有限制提交的資料。Post比Get安全,當資料是中文或者不敏感的資料,則用get,因為使用get,引數會顯示在地址,對於敏感資料和不是中文字元的資料,則用post。
(6),POST表示可能修改變伺服器上的資源的請求,在伺服器端,用Post方式提交的資料只能用Request.Form來獲取。
18 、什麼是cookie?Session和cookie有什麼區別?Cookie是會話技術,將使用者的資訊儲存到瀏覽器的物件.
區別:
(1)cookie資料存放在客戶的瀏覽器上,session資料放在伺服器上
(2)cookie不是很安全,別人可以分析存放在本地的COOKIE並進行COOKIE欺騙,如果主要考慮到安全應當使用session
(3)session會在一定時間內儲存在伺服器上。當訪問增多,會比較佔用你伺服器的效能,如果主要考慮到減輕伺服器效能方面,應當使用COOKIE
(4)單個cookie在客戶端的限制是3K,就是說一個站點在客戶端存放的COOKIE不能3K。
結論:
將登陸資訊等重要資訊存放為SESSION;其他資訊如果需要保留,可以放在COOKIE中。
19 、jsp和servlet的區別、共同點、各自應用的範圍?JSP是Servlet技術的擴充套件,本質上就是Servlet的簡易方式。JSP編譯後是“類servlet”。
Servlet和JSP最主要的不同點在於:Servlet的應用邏輯是在Java檔案中,並且完全從表示層中的HTML裡分離開來。而JSP的情況是Java和HTML可以組合成一個副檔名為.jsp的檔案。
JSP側重於檢視,Servlet主要用於控制邏輯。在struts框架中,JSP位於MVC設計模式的檢視層,而Servlet位於控制層.
20 、tomcat容器是如何建立servlet類例項?用到了什麼原理?當容器啟動時,會讀取在webapps目錄下所有的web應用中的web.xml檔案,然後對xml檔案進行解析,並讀取servlet註冊資訊。然後,將每個應用中註冊的servlet類都進行載入,並透過反射的方式例項化。(有時候也是在第一次請求時例項化)在servlet註冊時加上<load-on-startup>1</load-on-startup>如果為正數,則在一開始就例項化,如果不寫或為負數,則第一次請求例項化。
21、JDBC訪問資料庫的基本步驟是什麼?(1),載入驅動
(2),透過DriverManager物件獲取連線物件Connection
(3),透過連線物件獲取會話
(4),透過會話進行資料的增刪改查,封裝物件
(5),關閉資源
22 、說說preparedStatement和Statement的區別(1),效率:預編譯會話比普通會話物件,資料庫系統不會對相同的sql語句不會再次編譯
(2),安全性:可以有效的避免sql注入攻擊!sql注入攻擊就是從客戶端輸入一些非法的特殊字元,而使伺服器端在構造sql語句的時候仍然能夠正確構造,從而收集程式和伺服器的資訊和資料。比如:“select * from t_user where userName = ‘” + userName + “ ’ and password =’” + password + “’”如果使用者名稱和密碼輸入的是’1’ or ‘1’=’1’ ; 則生產的sql語句是:“select * from t_user where userName = ‘1’ or ‘1’ =’1’ and password =’1’ or ‘1’=’1’ 這個語句中的where 部分沒有起到對資料篩選的作用。
23 、說說事務的概念,在JDBC程式設計中處理事務的步驟。(1) 事務是作為單個邏輯工作單元執行的一系列操作。
(2),一個邏輯工作單元必須有四個屬性,稱為原子性、一致性、隔離性和永續性 (ACID) 屬性,只有這樣才能成為一個事務
事務處理步驟:
(3),conn.setAutoComit(false);設定提交方式為手工提交
(4),conn.commit()提交事務
(5),出現異常,回滾 conn.rollback();
24 、資料庫連線池的原理。為什麼要使用連線池。(1),資料庫連線是一件費時的操作,連線池可以使多個操作共享一個連線。
(2),資料庫連線池的基本思想就是為資料庫連線建立一個“緩衝池”。預先在緩衝池中放入一定數量的連線,當需要建立資料庫連線時,只需從“緩衝池”中取出一個,使用完畢之後再放回去。我們可以透過設定連線池最大連線數來防止系統無盡的與資料庫連線。更為重要的是我們可以透過連線池的管理機制監視資料庫的連線的數量、使用情況,為系統開發,測試及效能調整提供依據。
(3),使用連線池是為了提高對資料庫連線資源的管理
25 、JDBC的髒讀是什麼?哪種資料庫隔離級別能防止髒讀?當我們使用事務時,有可能會出現這樣的情況,有一行資料剛更新,與此同時另一個查詢讀到了這個剛更新的值。這樣就導致了髒讀,因為更新的資料還沒有進行持久化,更新這行資料的業務可能會進行回滾,這樣這個資料就是無效的。資料庫的TRANSACTIONREADCOMMITTED,TRANSACTIONREPEATABLEREAD,和TRANSACTION_SERIALIZABLE隔離級別可以防止髒讀。
26 、什麼是幻讀,哪種隔離級別可以防止幻讀?幻讀是指一個事務多次執行一條查詢返回的卻是不同的值。假設一個事務正根據某個條件進行資料查詢,然後另一個事務插入了一行滿足這個查詢條件的資料。之後這個事務再次執行了這條查詢,返回的結果集中會包含剛插入的那條新資料。這行新資料被稱為幻行,而這種現象就叫做幻讀。
只有TRANSACTION_SERIALIZABLE隔離級別才能防止產生幻讀。
27 、JDBC的DriverManager是用來做什麼的?JDBC的DriverManager是一個工廠類,我們透過它來建立資料庫連線。當JDBC的Driver類被載入進來時,它會自己註冊到DriverManager類裡面然後我們會把資料庫配置資訊傳成DriverManager.getConnection()方法,DriverManager會使用註冊到它裡面的驅動來獲取資料庫連線,並返回給呼叫的程式。
28、execute,executeQuery,executeUpdate的區別是什麼?(1),Statement的execute(String query)方法用來執行任意的SQL查詢,如果查詢的結果是一個ResultSet,這個方法就返回true。如果結果不是ResultSet,比如insert或者update查詢,它就會返回false。我們可以透過它的getResultSet方法來獲取ResultSet,或者透過getUpdateCount()方法來獲取更新的記錄條數。
(2),Statement的executeQuery(String query)介面用來執行select查詢,並且返回ResultSet。即使查詢不到記錄返回的ResultSet也不會為null。我們通常使用executeQuery來執行查詢語句,這樣的話如果傳進來的是insert或者update語句的話,它會丟擲錯誤資訊為 “executeQuery method can not be used for update”的java.util.SQLException。
(3),Statement的executeUpdate(String query)方法用來執行insert或者update/delete(DML)語句,或者 什麼也不返回,對於DDL語句,返回值是int型別,如果是DML語句的話,它就是更新的條數,如果是DDL的話,就返回0。只有當你不確定是什麼語句的時候才應該使用execute()方法,否則應該使用executeQuery或者executeUpdate方法。
29、SQL查詢出來的結果分頁展示一般怎麼做?Oracle:
MySQL:
sql server:
30、JDBC的ResultSet是什麼?在查詢資料庫後會返回一個ResultSet,它就像是查詢結果集的一張資料表。ResultSet物件維護了一個遊標,指向當前的資料行。開始的時候這個遊標指向的是第一行。如果呼叫了ResultSet的next()方法遊標會下移一行,如果沒有更多的資料了,next()方法會返回false。可以在for迴圈中用它來遍歷資料集。預設的ResultSet是不能更新的,遊標也只能往下移。也就是說你只能從第一行到最後一行遍歷一遍。不過也可以建立可以回滾或者可更新的ResultSet
當生成ResultSet的Statement物件要關閉或者重新執行或是獲取下一個ResultSet的時候,ResultSet物件也會自動關閉。可以透過ResultSet的getter方法,傳入列名或者從1開始的序號來獲取列資料。
以上就是我總結的這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值。
回覆列表
初學Java的話,先把基礎知識給掌握了,在學習後續的內容的時候,也不要放鬆對面試題的練習和複習鞏固;
以前學習Java看的是如鵬網的影片教程——《這樣學Java不枯燥》,透過開發超級瑪麗,飛機大戰等好多經典的小遊戲來講解Java的知識點,沒想到Java還可以這麼學,感覺挺好玩的;
還有每一章節後面的練習,不僅僅有程式設計的練習題,還有面試口才練習題,需要以錄音的方式提交,老師會指出那些回答的不到位的地方,應該從哪些方面去回答,從面試的角度去回答,為以後的面試提前做準備,打下基礎,挺不錯的,具體的可以到如鵬網去看看;