學(xué)習(xí)啦 > 創(chuàng)業(yè)指南 > 職場 > 求職面試技巧 > java面試一般會問什么

java面試一般會問什么

時(shí)間: 稱紅1024 分享

java面試一般會問什么

  面試是通過書面或面談的形式來考察一個(gè)人的工作能力與否,物以類聚,通過面試可以初步判斷應(yīng)聘者是否可以融入自己的團(tuán)隊(duì)。那么java面試一般會問什么呢?下面是學(xué)習(xí)啦小編給大家整理的java面試一般會問什么,供大家參閱!

  java面試一般會問什么

  1.java是否會出現(xiàn)內(nèi)存溢出?如何解決?

  內(nèi)存溢出是指應(yīng)用系統(tǒng)中存在無法回收的內(nèi)存或使用的內(nèi)存過多,最終使得程序運(yùn)行要用到的內(nèi)存大于虛擬機(jī)能提供的最大內(nèi)存。為了解決Java中內(nèi)存溢 出問題,我們首先必須了解Java是如何管理內(nèi)存的。Java的內(nèi)存管理就是對象的分配和釋放問題。在Java中,內(nèi)存的分配是由程序完成的,而內(nèi)存的釋 放是由垃圾收集器(Garbage Collection,GC)完成的,程序員不需要通過調(diào)用GC函數(shù)來釋放內(nèi)存,因?yàn)椴煌腏VM實(shí)現(xiàn)者可能使用不同的算法管理GC,有的是內(nèi)存使用到達(dá) 一定程度時(shí),GC才開始工作,也有定時(shí)執(zhí)行的,有的是中斷式執(zhí)行GC。但GC只能回收無用并且不再被其它對象引用的那些對象所占用的空間。Java的內(nèi)存 垃圾回收機(jī)制是從程序的主要運(yùn)行對象開始檢查引用鏈,當(dāng)遍歷一遍后發(fā)現(xiàn)沒有被引用的孤立對象就作為垃圾回收。

  引起內(nèi)存溢出的原因有很多種,常見的有以下幾種:

  l 內(nèi)存中加載的數(shù)據(jù)量過于龐大,如一次從數(shù)據(jù)庫取出過多數(shù)據(jù);

  l 集合類中有對對象的引用,使用完后未清空,使得JVM不能回收;

  l 代碼中存在死循環(huán)或循環(huán)產(chǎn)生過多重復(fù)的對象實(shí)體;

  l 使用的第三方軟件中的BUG;

  l 啟動參數(shù)內(nèi)存值設(shè)定的過小;

  3.內(nèi)存溢出的解決

  內(nèi)存溢出雖然很棘手,但也有相應(yīng)的解決辦法,可以按照從易到難,一步步的解決。

  第一步,就是修改JVM啟動參數(shù),直接增加內(nèi)存。這一點(diǎn)看上去似乎很簡單,但很容易被忽略。JVM默認(rèn)可以使用的內(nèi)存為64M,Tomcat默認(rèn)可 以使用的內(nèi)存為128MB,對于稍復(fù)雜一點(diǎn)的系統(tǒng)就會不夠用。在某項(xiàng)目中,就因?yàn)閱訁?shù)使用的默認(rèn)值,經(jīng)常報(bào)“OutOfMemory”錯(cuò)誤。因此,- Xms,-Xmx參數(shù)一定不要忘記加。

  第二步,檢查錯(cuò)誤日志,查看“OutOfMemory”錯(cuò)誤前是否有其它異?;蝈e(cuò)誤。在一個(gè)項(xiàng)目中,使用兩個(gè)數(shù)據(jù) 庫連接,其中專用于發(fā)送短信的數(shù)據(jù)庫連接使用DBCP連接池管理,用戶為不將短信發(fā)出,有意將數(shù)據(jù)庫連接用戶名改錯(cuò),使得日志中有許多數(shù)據(jù)庫連接異常的日 志,一段時(shí)間后,就出現(xiàn)“OutOfMemory”錯(cuò)誤。經(jīng)分析,這是由于DBCP連接池BUG引起的,數(shù)據(jù)庫連接不上后,沒有將連接釋放,最終使得 DBCP報(bào)“OutOfMemory”錯(cuò)誤。經(jīng)過修改正確數(shù)據(jù)庫連接參數(shù)后,就沒有再出現(xiàn)內(nèi)存溢出的錯(cuò)誤。

  查看日志對于分析內(nèi)存溢出是非常重要的,通過仔細(xì)查看日志,分析內(nèi)存溢出前做過哪些操作,可以大致定位有問題的模塊。

  第三步,安排有經(jīng)驗(yàn)的編程人員對代碼進(jìn)行走查和分析,找出可能發(fā)生內(nèi)存溢出的位置。重點(diǎn)排查以下幾點(diǎn):

  l 檢查代碼中是否有死循環(huán)或遞歸調(diào)用。

  l 檢查是否有大循環(huán)重復(fù)產(chǎn)生新對象實(shí)體。

  l 檢查對數(shù)據(jù)庫查詢中,是否有一次獲得全部數(shù)據(jù)的查詢。一般來說,如果一次取十萬條記錄到內(nèi)存,就可能引起內(nèi)存溢出。這個(gè)問題比較隱蔽,在上線前,數(shù)據(jù)庫中 數(shù)據(jù)較少,不容易出問題,上線后,數(shù)據(jù)庫中數(shù)據(jù)多了,一次查詢就有可能引起內(nèi)存溢出。因此對于數(shù)據(jù)庫查詢盡量采用分頁的方式查詢。

  l 檢查List、MAP等集合對象是否有使用完后,未清除的問題。List、MAP等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。

  第四步,使用內(nèi)存查看工具動態(tài)查看內(nèi)存使用情況。某個(gè)項(xiàng)目上線后,每次系統(tǒng)啟動兩天后,就會出現(xiàn)內(nèi)存溢出的錯(cuò)誤。這種情況一般是代碼中出現(xiàn)了緩慢的內(nèi)存泄漏,用上面三個(gè)步驟解決不了,這就需要使用內(nèi)存查看工具了。

  原因有很多種,比如:

  1.數(shù)據(jù)量過于龐大;死循環(huán) ;靜態(tài)變量和靜態(tài)方法過多;遞歸;無法確定是否被引用的對象;

  2.虛擬機(jī)不回收內(nèi)存(內(nèi)存泄漏);

  說白了就是程序運(yùn)行要用到的內(nèi)存大于虛擬機(jī)能提供的最大內(nèi)存就發(fā)生內(nèi)存溢出了。 內(nèi)存溢出的問題要看業(yè)務(wù)和系統(tǒng)大小而定,對于某些系統(tǒng)可能內(nèi)存溢出不常見,但某些系統(tǒng)還是很常見的解決的方法,

  一個(gè)是優(yōu)化程序代碼,如果業(yè)務(wù)龐大,邏輯復(fù)雜,盡量減少全局變量的引用,讓程序使用完變量的時(shí)候釋放該引用能夠讓垃圾回收器回收,釋放資源。

  二就是物理解決,增大物理內(nèi)存,然后通過:-Xms256m -Xmx256m -XX:MaxNewSize=256m -XX:MaxPermSize=256m的修改

  2.說說JVM內(nèi)存組成

  簡單的說 java中的堆和棧

  java把內(nèi)存分兩種:一種是棧內(nèi)存,另一種是堆內(nèi)存

  1。在函數(shù)中定義的基本類型變量和對象的引用變量都在函數(shù)的棧內(nèi)存中分配;

  2。堆內(nèi)存用來存放由 new創(chuàng)建的對象和數(shù)組

  在函數(shù)(代碼塊)中定義一個(gè)變量時(shí), java就在棧中為這個(gè)變量分配內(nèi)存空間,當(dāng)超過變量的作用域后, java會自動釋放掉為該變量所分配的內(nèi)存空間;在堆中分配的內(nèi)存由 java虛擬機(jī)的自動垃圾回收器來管理

  堆的優(yōu)勢是可以動態(tài)分配內(nèi)存大小,生存期也不必事先告訴編譯器,因?yàn)樗窃谶\(yùn)行時(shí)動態(tài)分配內(nèi)存的。缺點(diǎn)就是要在運(yùn)行時(shí)動態(tài)分配內(nèi)存,存取速度較慢;

  棧的優(yōu)勢是存取速度比堆要快,缺點(diǎn)是存在棧中的數(shù)據(jù)大小與生存期必須是確定的無靈活 性。

  java 堆分為三個(gè)區(qū): New 、 Old 和 Permanent

  GC 有兩個(gè)線程:

  新創(chuàng)建的對象被分配到 New 區(qū),當(dāng)該區(qū)被填滿時(shí)會被 GC 輔助線程移到 Old 區(qū),當(dāng) Old 區(qū)也填滿了會觸發(fā) GC 主線程遍歷堆內(nèi)存里的所有對象。 Old 區(qū)的大小等于 Xmx 減去 -Xmn

  java棧存放

  棧調(diào)整:參數(shù)有 +UseDefaultStackSize -Xss256K,表示每個(gè)線程可申請 256k的棧空間

  每個(gè)線程都有他自己的 Stack

  3、”static”關(guān)鍵字是什么意思?Java中是否可以覆蓋(override)一個(gè)private或者是static的方法?

  “static”關(guān)鍵字表明一個(gè)成員變量或者是成員方法可以在沒有所屬的類的實(shí)例變量的情況下被訪問。

  Java中static方法不能被覆蓋,因?yàn)榉椒ǜ采w是基于運(yùn)行時(shí)動態(tài)綁定的,而static方法是編譯時(shí)靜態(tài)綁定的。static方法跟類的任何實(shí)例都不相關(guān),所以概念上不適用。

  4、是否可以在static環(huán)境中訪問非static變量?

  static變量在Java中是屬于類的,它在所有的實(shí)例中的值是一樣的。當(dāng)類被Java虛擬機(jī)載入的時(shí)候,會對static變量進(jìn)行初始化。如果你的代碼嘗試不用實(shí)例來訪問非static的變量,編譯器會報(bào)錯(cuò),因?yàn)檫@些變量還沒有被創(chuàng)建出來,還沒有跟任何實(shí)例關(guān)聯(lián)上。

  5.JDK和JRE的區(qū)別是什么?

  Java Development Kit,Java開發(fā)包 jre ---Java Runtime Environment java運(yùn)行環(huán)境

  Java運(yùn)行時(shí)環(huán)境(JRE)是將要執(zhí)行Java程序的Java虛擬機(jī)。它同時(shí)也包含了執(zhí)行applet需要的瀏覽器插件。Java開發(fā)工具包 (JDK)是完整的Java軟件開發(fā)包,包含了JRE,編譯器和其他的工具(比如:JavaDoc,Java調(diào)試器),可以讓開發(fā)者開發(fā)、編譯、執(zhí)行 Java應(yīng)用程序。

  面試的形式

  面試有很多形式,依據(jù)面試的內(nèi)容與要求,大致可以分為以下幾種:

  問題式

  由招聘者按照事先擬訂的提綱對求職者進(jìn)行發(fā)問,請予回答。其目的在于觀察求職者在特殊環(huán)境中的表現(xiàn),考核其知識與業(yè)務(wù),判斷其解決問題的能力,從而獲得有關(guān)求職者的第一手資料。

  壓力式

  由招聘者有意識地對求職者施加壓力,就某一問題或某一事件作一連串的發(fā)問,詳細(xì)具體且追根問底,直至無以對答。此方式主要觀察求職者在特殊壓力下的反應(yīng)、思維敏捷程度及應(yīng)變能力。

  隨意式

  即招聘者與求職者海闊天空、漫無邊際地進(jìn)行交談,氣氛輕松活躍,無拘無束,招聘者與求職者自由發(fā)表言論,各抒己見。此方式的目的為:于閑聊中觀察應(yīng)試者談吐、舉止、知識、能力、氣質(zhì)和風(fēng)度,對其做全方位的綜合素質(zhì)考察。

  情景式

  由招聘者事先設(shè)定一個(gè)情景,提出一個(gè)問題或一項(xiàng)計(jì)劃,請求職者進(jìn)入角色模擬完成,其目的在于考核其分析問題、解決問題的能力。

  綜合式

  招聘者通過多種方式考察求職者的綜合能力和素質(zhì),如用外語與其交談,要求即時(shí)作文,或即興演講,或要求寫一段文字,甚至操作一下計(jì)算機(jī)等等,以考察其外語水平,文字能力,書法及口才表達(dá)等各方面的能力。

  以上是根據(jù)面試種類所做的大致劃分,在實(shí)際面試過程中,招聘者可能采取一種或同時(shí)采取幾種面試方式,也可能就某一方面的問題對求職者進(jìn)行更廣泛更深刻即深層次的考察,其目的在于能夠選拔出優(yōu)秀的應(yīng)聘者。

java面試一般會問什么相關(guān)文章:

1.java面試官如何提問

2.java面試官面試技巧

3.java面試時(shí)自我介紹

4.應(yīng)屆生java面試自我介紹演講稿

5.有關(guān)java應(yīng)屆生的求職面試技巧

3629368