經(jīng)典面試筆記,資深Java工程師面試題

經(jīng)典面試筆記,資深Java工程師面試題

北大青鳥長(zhǎng)沙麓谷校區(qū)      2022-05-06 19:14:01     52

經(jīng)典面試筆記,資深Java工程師面試題,  今天要談的主題是關(guān)于求職,求職是在每個(gè)技術(shù)人員的生涯中都要經(jīng)歷多次。對(duì)于我們大部分人而言,在進(jìn)入自己心儀的公司之前少

課程價(jià)格 請(qǐng)咨詢

上課時(shí)段: 授課校區(qū):

詳細(xì)介紹

  今天要談的主題是關(guān)于求職,求職是在每個(gè)技術(shù)人員的生涯中都要經(jīng)歷多次。對(duì)于我們大部分人而言,在進(jìn)入自己心儀的公司之前少不了準(zhǔn)備工作,有一份全面細(xì)致面試題將幫助我們減少許多麻煩。在跳槽季來(lái)臨之前,特地做這個(gè)系列的文章,一方面幫助自己鞏固下基礎(chǔ),另一方面也希望幫助想要換工作的朋友。



  相關(guān)概念


  面向?qū)ο?strong>的三個(gè)特征


  封裝,繼承,多態(tài),這個(gè)應(yīng)該是人人皆知,有時(shí)候也會(huì)加上抽象。


  多態(tài)的好處


  允許不同類對(duì)象對(duì)同一消息做出響應(yīng),即同一消息可以根據(jù)發(fā)送對(duì)象的不同而采用多種不同的行為方式(發(fā)送消息就是函數(shù)調(diào)用)。主要有以下優(yōu)點(diǎn):


  1.可替換性:多態(tài)對(duì)已存在代碼具有可替換性


  2.可擴(kuò)充性:增加新的子類不影響已經(jīng)存在的類結(jié)構(gòu)


  3.接口性:多態(tài)是超類通過方法簽名,向子類提供一個(gè)公共接口,由子類來(lái)完善或者重寫它來(lái)實(shí)現(xiàn)的。


  4.靈活性


  5.簡(jiǎn)化性


  代碼中如何實(shí)現(xiàn)多態(tài)


  實(shí)現(xiàn)多態(tài)主要有以下三種方式:


  1.接口實(shí)現(xiàn)


  2.繼承父類重寫方法


  3.同一類中進(jìn)行方法重載


  虛擬機(jī)是如何實(shí)現(xiàn)多態(tài)的


  動(dòng)態(tài)綁定技術(shù)(dynamicbinding),執(zhí)行期間判斷所引用對(duì)象的實(shí)際類型,根據(jù)實(shí)際類型調(diào)用對(duì)應(yīng)的方法。


  接口的意義


  接口的意義用三個(gè)詞就可以概括:規(guī)范,擴(kuò)展,回調(diào)。


  抽象類的意義


  抽象類的意義可以用三句話來(lái)概括:


  1.為其他子類提供一個(gè)公共的類型


  2.封裝子類中重復(fù)定義的內(nèi)容


  3.定義抽象方法,子類雖然有不同的實(shí)現(xiàn),但是定義時(shí)一致的


  接口和抽象類的區(qū)別


  比較抽象類接口默認(rèn)方法抽象類可以有默認(rèn)的方法實(shí)現(xiàn)java8之前,接口中不存在方法的實(shí)現(xiàn).實(shí)現(xiàn)方式子類使用extends關(guān)鍵字來(lái)繼承抽象類.如果子類不是抽象類,子類需要提供抽象類中所聲明方法的實(shí)現(xiàn).子類使用implements來(lái)實(shí)現(xiàn)接口,需要提供接口中所有聲明的實(shí)現(xiàn).構(gòu)造器抽象類中可以有構(gòu)造器,接口中不能和正常類區(qū)別抽象類不能被實(shí)例化接口則是完全不同的類型訪問修飾符抽象方法可以有public,protected和default等修飾接口默認(rèn)是public,不能使用其他修飾符多繼承一個(gè)子類只能存在一個(gè)父類一個(gè)子類可以存在多個(gè)接口添加新方法想抽象類中添加新方法,可以提供默認(rèn)的實(shí)現(xiàn),因此可以不修改子類現(xiàn)有的代碼如果往接口中添加新方法,則子類中需要實(shí)現(xiàn)該方法.


  父類的靜態(tài)方法能否被子類重寫


  不能。重寫只適用于實(shí)例方法,不能用于靜態(tài)方法,而子類當(dāng)中含有和父類相同簽名的靜態(tài)方法,我們一般稱之為隱藏。


  什么是不可變對(duì)象


  不可變對(duì)象指對(duì)象一旦被創(chuàng)建,狀態(tài)就不能再改變。任何修改都會(huì)創(chuàng)建一個(gè)新的對(duì)象,如String、Integer及其它包裝類。


  靜態(tài)變量和實(shí)例變量的區(qū)別?


  靜態(tài)變量存儲(chǔ)在方法區(qū),屬于類所有。實(shí)例變量存儲(chǔ)在堆當(dāng)中,其引用存在當(dāng)前線程棧。


  能否創(chuàng)建一個(gè)包含可變對(duì)象的不可變對(duì)象?


  當(dāng)然可以創(chuàng)建一個(gè)包含可變對(duì)象的不可變對(duì)象的,你只需要謹(jǐn)慎一點(diǎn),不要共享可變對(duì)象的引用就可以了,如果需要變化時(shí),就返回原對(duì)象的一個(gè)拷貝。最常見的例子就是對(duì)象中包含一個(gè)日期對(duì)象的引用。


  Java創(chuàng)建對(duì)象的幾種方式


  1.采用new


  2.通過反射


  3.采用clone


  4.通過序列化機(jī)制


  前2者都需要顯式地調(diào)用構(gòu)造方法。造成耦合性最高的恰好是第一種,因此你發(fā)現(xiàn)無(wú)論什么框架,只要涉及到解耦必先減少new的使用。


  switch中能否使用string做參數(shù)


  在idk1.7之前,switch只能支持byte,short,char,int或者其對(duì)應(yīng)的封裝類以及Enum類型。從idk1.7之后switch開始支持String。


  switch能否作用在byte,long上?


  可以用在byte上,但是不能用在long上。


  Strings1=”ab”,Strings2=”a”+”b”,Strings3=”a”,Strings4=”b”,s5=s3+s4請(qǐng)問s5==s2返回什么?


  返回false。在編譯過程中,編譯器會(huì)將s2直接優(yōu)化為”ab”,會(huì)將其放置在常量池當(dāng)中,s5則是被創(chuàng)建在堆區(qū),相當(dāng)于s5=newString(“ab”);


  Java當(dāng)中的四種引用


  強(qiáng)引用,軟引用,弱引用,虛引用。不同的引用類型主要體現(xiàn)在GC上:


  1.強(qiáng)引用:如果一個(gè)對(duì)象具有強(qiáng)引用,它就不會(huì)被垃圾回收器回收。即使當(dāng)前內(nèi)存空間不足,JVM也不會(huì)回收它,而是拋出OutOfMemoryError錯(cuò)誤,使程序異常終止。如果想中斷強(qiáng)引用和某個(gè)對(duì)象之間的關(guān)聯(lián),可以顯式地將引用賦值為null,這樣一來(lái)的話,JVM在合適的時(shí)間就會(huì)回收該對(duì)象。


  2.軟引用:在使用軟引用時(shí),如果內(nèi)存的空間足夠,軟引用就能繼續(xù)被使用,而不會(huì)被垃圾回收器回收,只有在內(nèi)存不足時(shí),軟引用才會(huì)被垃圾回收器回收。


  3.弱引用:具有弱引用的對(duì)象擁有的生命周期更短暫。因?yàn)楫?dāng)JVM進(jìn)行垃圾回收,一旦發(fā)現(xiàn)弱引用對(duì)象,無(wú)論當(dāng)前內(nèi)存空間是否充足,都會(huì)將弱引用回收。不過由于垃圾回收器是一個(gè)優(yōu)先級(jí)較低的線程,所以并不一定能迅速發(fā)現(xiàn)弱引用對(duì)象。


  4.虛引用:顧名思義,就是形同虛設(shè),如果一個(gè)對(duì)象僅持有虛引用,那么它相當(dāng)于沒有引用,在任何時(shí)候都可能被垃圾回收器回收。


  Java中==和eqauls()的區(qū)別,equals()和`hashcode的區(qū)別


  ==是運(yùn)算符,用于比較兩個(gè)變量是否相等,而equals是Object類的方法,用于比較兩個(gè)對(duì)象是否相等。默認(rèn)Object類的equals方法是比較兩個(gè)對(duì)象的地址,此時(shí)和==的結(jié)果一樣。換句話說(shuō):基本類型比較用==,比較的是他們的值。默認(rèn)下,對(duì)象用==比較時(shí),比較的是內(nèi)存地址,如果需要比較對(duì)象內(nèi)容,需要重寫equal方法。


  equals()和hashcode()的聯(lián)系


  hashCode()是Object類的一個(gè)方法,返回一個(gè)哈希值。如果兩個(gè)對(duì)象根據(jù)equal()方法比較相等,那么調(diào)用這兩個(gè)對(duì)象中任意一個(gè)對(duì)象的hashCode()方法必須產(chǎn)生相同的哈希值。


  如果兩個(gè)對(duì)象根據(jù)eqaul()方法比較不相等,那么產(chǎn)生的哈希值不一定相等(碰撞的情況下還是會(huì)相等的。)


  a.hashCode()有什么用?與a.equals(b)有什么關(guān)系


  hashCode()方法是相應(yīng)對(duì)象整型的hash值。它常用于基于hash的集合類,如Hashtable、HashMap、linkedHashMap等等。它與equals()方法關(guān)系特別緊密。根據(jù)Java規(guī)范,使用equal()方法來(lái)判斷兩個(gè)相等的對(duì)象,必須具有相同的hashcode。


  將對(duì)象放入到集合中時(shí),首先判斷要放入對(duì)象的hashcode是否已經(jīng)在集合中存在,不存在則直接放入集合。如果hashcode相等,然后通過equal()方法判斷要放入對(duì)象與集合中的任意對(duì)象是否相等:如果equal()判斷不相等,直接將該元素放入集合中,否則不放入。


  以上就是小編對(duì)Java面試的總結(jié),你是否已經(jīng)對(duì)Java面試有了一定了解了呢,小編在這里建議大家在日常中多寫多敲代碼,好的代碼與扎實(shí)的基礎(chǔ)知識(shí)一定是實(shí)踐出來(lái)的。


  最后,每一位讀到這里的網(wǎng)友,感謝你們能耐心地看完。希望在成為一名更優(yōu)秀的Java程序員的道路上,我們可以一起學(xué)習(xí)、一起進(jìn)步!都能贏取白富美,走向架構(gòu)師的人生巔峰!


培訓(xùn)啦提醒您:交易時(shí)請(qǐng)核實(shí)對(duì)方資質(zhì),對(duì)于過大宣傳或承諾需謹(jǐn)慎!任何要求預(yù)付定金、匯款等方式均存在風(fēng)險(xiǎn),謹(jǐn)防上當(dāng)。