java面試一般會問什么
java面試一般會問什么
面試是通過書面或面談的形式來考察一個人的工作能力與否,物以類聚,通過面試可以初步判斷應(yīng)聘者是否可以融入自己的團(tuán)隊。那么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)存,因為不同的JVM實現(xiàn)者可能使用不同的算法管理GC,有的是內(nèi)存使用到達(dá) 一定程度時,GC才開始工作,也有定時執(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ù)的對象實體;
l 使用的第三方軟件中的BUG;
l 啟動參數(shù)內(nèi)存值設(shè)定的過小;
3.內(nèi)存溢出的解決
內(nèi)存溢出雖然很棘手,但也有相應(yīng)的解決辦法,可以按照從易到難,一步步的解決。
第一步,就是修改JVM啟動參數(shù),直接增加內(nèi)存。這一點看上去似乎很簡單,但很容易被忽略。JVM默認(rèn)可以使用的內(nèi)存為64M,Tomcat默認(rèn)可 以使用的內(nèi)存為128MB,對于稍復(fù)雜一點的系統(tǒng)就會不夠用。在某項目中,就因為啟動參數(shù)使用的默認(rèn)值,經(jīng)常報“OutOfMemory”錯誤。因此,- Xms,-Xmx參數(shù)一定不要忘記加。
第二步,檢查錯誤日志,查看“OutOfMemory”錯誤前是否有其它異?;蝈e誤。在一個項目中,使用兩個數(shù)據(jù) 庫連接,其中專用于發(fā)送短信的數(shù)據(jù)庫連接使用DBCP連接池管理,用戶為不將短信發(fā)出,有意將數(shù)據(jù)庫連接用戶名改錯,使得日志中有許多數(shù)據(jù)庫連接異常的日 志,一段時間后,就出現(xiàn)“OutOfMemory”錯誤。經(jīng)分析,這是由于DBCP連接池BUG引起的,數(shù)據(jù)庫連接不上后,沒有將連接釋放,最終使得 DBCP報“OutOfMemory”錯誤。經(jīng)過修改正確數(shù)據(jù)庫連接參數(shù)后,就沒有再出現(xiàn)內(nèi)存溢出的錯誤。
查看日志對于分析內(nèi)存溢出是非常重要的,通過仔細(xì)查看日志,分析內(nèi)存溢出前做過哪些操作,可以大致定位有問題的模塊。
第三步,安排有經(jīng)驗的編程人員對代碼進(jìn)行走查和分析,找出可能發(fā)生內(nèi)存溢出的位置。重點排查以下幾點:
l 檢查代碼中是否有死循環(huán)或遞歸調(diào)用。
l 檢查是否有大循環(huán)重復(fù)產(chǎn)生新對象實體。
l 檢查對數(shù)據(jù)庫查詢中,是否有一次獲得全部數(shù)據(jù)的查詢。一般來說,如果一次取十萬條記錄到內(nèi)存,就可能引起內(nèi)存溢出。這個問題比較隱蔽,在上線前,數(shù)據(jù)庫中 數(shù)據(jù)較少,不容易出問題,上線后,數(shù)據(jù)庫中數(shù)據(jù)多了,一次查詢就有可能引起內(nèi)存溢出。因此對于數(shù)據(jù)庫查詢盡量采用分頁的方式查詢。
l 檢查List、MAP等集合對象是否有使用完后,未清除的問題。List、MAP等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。
第四步,使用內(nèi)存查看工具動態(tài)查看內(nèi)存使用情況。某個項目上線后,每次系統(tǒng)啟動兩天后,就會出現(xiàn)內(nèi)存溢出的錯誤。這種情況一般是代碼中出現(xiàn)了緩慢的內(nèi)存泄漏,用上面三個步驟解決不了,這就需要使用內(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)還是很常見的解決的方法,
一個是優(yōu)化程序代碼,如果業(yè)務(wù)龐大,邏輯復(fù)雜,盡量減少全局變量的引用,讓程序使用完變量的時候釋放該引用能夠讓垃圾回收器回收,釋放資源。
二就是物理解決,增大物理內(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ù)(代碼塊)中定義一個變量時, java就在棧中為這個變量分配內(nèi)存空間,當(dāng)超過變量的作用域后, java會自動釋放掉為該變量所分配的內(nèi)存空間;在堆中分配的內(nèi)存由 java虛擬機(jī)的自動垃圾回收器來管理
堆的優(yōu)勢是可以動態(tài)分配內(nèi)存大小,生存期也不必事先告訴編譯器,因為它是在運(yùn)行時動態(tài)分配內(nèi)存的。缺點就是要在運(yùn)行時動態(tài)分配內(nèi)存,存取速度較慢;
棧的優(yōu)勢是存取速度比堆要快,缺點是存在棧中的數(shù)據(jù)大小與生存期必須是確定的無靈活 性。
java 堆分為三個區(qū): New 、 Old 和 Permanent
GC 有兩個線程:
新創(chuàng)建的對象被分配到 New 區(qū),當(dāng)該區(qū)被填滿時會被 GC 輔助線程移到 Old 區(qū),當(dāng) Old 區(qū)也填滿了會觸發(fā) GC 主線程遍歷堆內(nèi)存里的所有對象。 Old 區(qū)的大小等于 Xmx 減去 -Xmn
java棧存放
棧調(diào)整:參數(shù)有 +UseDefaultStackSize -Xss256K,表示每個線程可申請 256k的??臻g
每個線程都有他自己的 Stack
3、”static”關(guān)鍵字是什么意思?Java中是否可以覆蓋(override)一個private或者是static的方法?
“static”關(guān)鍵字表明一個成員變量或者是成員方法可以在沒有所屬的類的實例變量的情況下被訪問。
Java中static方法不能被覆蓋,因為方法覆蓋是基于運(yùn)行時動態(tài)綁定的,而static方法是編譯時靜態(tài)綁定的。static方法跟類的任何實例都不相關(guān),所以概念上不適用。
4、是否可以在static環(huán)境中訪問非static變量?
static變量在Java中是屬于類的,它在所有的實例中的值是一樣的。當(dāng)類被Java虛擬機(jī)載入的時候,會對static變量進(jìn)行初始化。如果你的代碼嘗試不用實例來訪問非static的變量,編譯器會報錯,因為這些變量還沒有被創(chuàng)建出來,還沒有跟任何實例關(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)行時環(huán)境(JRE)是將要執(zhí)行Java程序的Java虛擬機(jī)。它同時也包含了執(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è)定一個情景,提出一個問題或一項計劃,請求職者進(jìn)入角色模擬完成,其目的在于考核其分析問題、解決問題的能力。
綜合式
招聘者通過多種方式考察求職者的綜合能力和素質(zhì),如用外語與其交談,要求即時作文,或即興演講,或要求寫一段文字,甚至操作一下計算機(jī)等等,以考察其外語水平,文字能力,書法及口才表達(dá)等各方面的能力。
以上是根據(jù)面試種類所做的大致劃分,在實際面試過程中,招聘者可能采取一種或同時采取幾種面試方式,也可能就某一方面的問題對求職者進(jìn)行更廣泛更深刻即深層次的考察,其目的在于能夠選拔出優(yōu)秀的應(yīng)聘者。
java面試一般會問什么相關(guān)文章: