更新時間:2019-10-25 15:13:13 來源:動力節(jié)點 瀏覽2917次
Java開發(fā)實用的面試題及參考答案分享,Java程序員面試過程中少不了專業(yè)上的考試,那么面試過程中面試官會問些什么問題呢?接下來小編帶你一起來進入面試環(huán)節(jié):
1、進程,線程,協(xié)程之間的區(qū)別是什么?
簡而言之,進程是程序運行和資源分配的基本單位,一個程序至少有一個進程,一個進程至少有一個線程。進程在執(zhí)行過程中擁有獨立的內(nèi)存單元,而多個線程共享內(nèi)存資源,減少切換次數(shù),從而效率更高。線程是進程的一個實體,是cpu調(diào)度和分派的基本單位,是比程序更小的能獨立運行的基本單位。同一進程中的多個線程之間可以并發(fā)執(zhí)行。
2、你了解守護線程嗎?它和非守護線程有什么區(qū)別
程序運行完畢,jvm會等待非守護線程完成后關閉,但是jvm不會等待守護線程。守護線程最典型的例子就是GC線程。
3、什么是多線程上下文切換
多線程的上下文切換是指CPU控制權由一個已經(jīng)正在運行的線程切換到另外一個就緒并等待獲取CPU執(zhí)行權的線程的過程。
4、創(chuàng)建兩種線程的方式?他們有什么區(qū)別?
通過實現(xiàn)java.lang.Runnable或者通過擴展java.lang.Thread類。相比擴展Thread,實現(xiàn)Runnable接口可能更優(yōu).原因有二:
Java不支持多繼承。因此擴展Thread類就代表這個子類不能擴展其他類。而實現(xiàn)Runnable接口的類還可能擴展另一個類。
類可能只要求可執(zhí)行即可,因此繼承整個Thread類的開銷過大。
5、Thread類中的start()和run()方法有什么區(qū)別?
start()方法被用來啟動新創(chuàng)建的線程,而且start()內(nèi)部調(diào)用了run()方法,這和直接調(diào)用run()方法的效果不一樣。當你調(diào)用run()方法的時候,只會是在原來的線程中調(diào)用,沒有新的線程啟動,start()方法才會啟動新線程。
6、怎么檢測一個線程是否持有對象監(jiān)視器?
Thread類提供了一個holdsLock(Objectobj)方法,當且僅當對象obj的監(jiān)視器被某條線程持有的時候才會返回true,注意這是一個static方法,這意味著”某條線程”指的是當前線程。
7、Runnable和Callable的區(qū)別是什么?
Runnable接口中的run()方法的返回值是void,它做的事情只是純粹地去執(zhí)行run()方法中的代碼而已;Callable接口中的call()方法是有返回值的,是一個泛型,和Future、FutureTask配合可以用來獲取異步執(zhí)行的結(jié)果。
這其實是很有用的一個特性,因為多線程相比單線程更難、更復雜的一個重要原因就是因為多線程充滿著未知性,某條線程是否執(zhí)行了?某條線程執(zhí)行了多久?某條線程執(zhí)行的時候我們期望的數(shù)據(jù)是否已經(jīng)賦值完畢?無法得知,我們能做的只是等待這條多線程的任務執(zhí)行完畢而已。而Callable+Future/FutureTask卻可以方便獲取多線程運行的結(jié)果,可以在等待時間太長沒獲取到需要的數(shù)據(jù)的情況下取消該線程的任務。
8、你知道哪些垃圾回收算法?
垃圾回收從理論上非常容易理解,具體的方法有以下幾種:
1.標記-清除
2.標記-復制
3.標記-整理
4.分代回收
9、如何判斷一個對象是否應該被回收
這就是所謂的對象存活性判斷,常用的方法有兩種:1.引用計數(shù)法;2.對象可達性分析。由于引用計數(shù)法存在互相引用導致無法進行GC的問題,所以目前JVM虛擬機多使用對象可達性分析算法。
10、簡單的解釋一下垃圾回收
Java垃圾回收機制最基本的做法是分代回收。內(nèi)存中的區(qū)域被劃分成不同的世代,對象根據(jù)其存活的時間被保存在對應世代的區(qū)域中。一般的實現(xiàn)是劃分成3個世代:年輕、年老和永久。內(nèi)存的分配是發(fā)生在年輕世代中的。當一個對象存活時間足夠長的時候,它就會被復制到年老世代中。對于不同的世代可以使用不同的垃圾回收算法。進行世代劃分的出發(fā)點是對應用中對象存活時間進行研究之后得出的統(tǒng)計規(guī)律。一般來說,一個應用中的大部分對象的存活時間都很短。比如局部變量的存活時間就只在方法的執(zhí)行過程中。基于這一點,對于年輕世代的垃圾回收算法就可以很有針對性。
11、調(diào)用System.gc()會發(fā)生什么?
通知GC開始工作,但是GC真正開始的時間不確定。
12、64位的JVM當中,int的長度是多少?
Java中,int類型變量的長度是一個固定值,與平臺無關,都是32位。意思就是說,在32位和64位的Java虛擬機中,int類型的長度是相同的。
13、int和Integer的區(qū)別
Integer是int的包裝類型,在拆箱和裝箱中,二者自動轉(zhuǎn)換。int是基本類型,直接存數(shù)值,而integer是對象,用一個引用指向這個對象。
14、int和Integer誰占用的內(nèi)存更多?
Integer對象會占用更多的內(nèi)存。Integer是一個對象,需要存儲對象的元數(shù)據(jù)。但是int是一個原始類型的數(shù)據(jù),所以占用的空間更少。
15、String,StringBuffer和StringBuilder區(qū)別
String是字符串常量,final修飾:StringBuffer字符串變量(線程安全);
StringBuilder字符串變量(線程不安全)。
16、String和StringBuffer
String和StringBuffer主要區(qū)別是性能:String是不可變對象,每次對String類型進行操作都等同于產(chǎn)生了一個新的String對象,然后指向新的String對象。所以盡量不在對String進行大量的拼接操作,否則會產(chǎn)生很多臨時對象,導致GC開始工作,影響系統(tǒng)性能。
StringBuffer是對對象本身操作,而不是產(chǎn)生新的對象,因此在有大量拼接的情況下,我們建議使用StringBuffer。
但是需要注意現(xiàn)在JVM會對String拼接做一定的優(yōu)化:
Strings=“Thisisonly”+”simple”+”test”會被虛擬機直接優(yōu)化成Strings=“Thisisonlysimpletest”,此時就不存在拼接過程。
17、StringBuffer和StringBuilder
StringBuffer是線程安全的可變字符串,其內(nèi)部實現(xiàn)是可變數(shù)組。StringBuilder是jdk1.5新增的,其功能和StringBuffer類似,但是非線程安全。因此,在沒有多線程問題的前提下,使用StringBuilder會取得更好的性能。
18、什么是編譯器常量?使用它有什么風險?
公共靜態(tài)不可變(publicstaticfinal)變量也就是我們所說的編譯期常量,這里的public可選的。實際上這些變量在編譯時會被替換掉,因為編譯器知道這些變量的值,并且知道這些變量在運行時不能改變。這種方式存在的一個問題是你使用了一個內(nèi)部的或第三方庫中的公有編譯時常量,但是這個值后面被其他人改變了,但是你的客戶端仍然在使用老的值,甚至你已經(jīng)部署了一個新的jar。為了避免這種情況,當你在更新依賴JAR文件時,確保重新編譯你的程序。
19、java當中使用什么類型表示價格比較好?
如果不是特別關心內(nèi)存和性能的話,使用BigDecimal,否則使用預定義精度的double類型。
20、如何將byte轉(zhuǎn)為String
可以使用String接收byte[]參數(shù)的構(gòu)造器來進行轉(zhuǎn)換,需要注意的點是要使用的正確的編碼,否則會使用平臺默認編碼,這個編碼可能跟原來的編碼相同,也可能不同。
以上就是動力節(jié)點java學院小編分享的“ 2019年Java開發(fā)實用的面試題及參考答案”的內(nèi)容,希望能夠幫助到大家,更多java最新面試題請繼續(xù)關注動力節(jié)點java學院官網(wǎng),每天會有精彩內(nèi)容分享與你。
相關面試題推薦