標(biāo)簽:Java面試,? 面向?qū)ο螅€程、2017/05/09 09:23
一.面向?qū)ο缶幊?/b>
1.JRE、JDK的區(qū)別
JRE(Java Run environment):Java運(yùn)行環(huán)境就是jvm+瀏覽器等一些插件。JDK是Java開發(fā)軟件包,包含了JRE、編譯器、其他工具(JavaDoc、Java調(diào)試器);
2.Java中是否可以覆蓋一個(gè)static或者private的方法?
“static”關(guān)鍵字說明一個(gè)成員變量或者成員方法,可以在沒有所屬類的實(shí)例變量情況下被訪問。
static方法不能被覆蓋,因?yàn)榉椒ǜ采w是針對動(dòng)態(tài)運(yùn)行時(shí)而言的,而static是編譯時(shí)靜態(tài)綁定的,static方法與任何實(shí)例都不相關(guān)。
同理,static環(huán)境下是不可以訪問非static變量,因?yàn)閟tatic屬于類的,它在所有的實(shí)例中的值都是一樣的,當(dāng)類被Java虛擬機(jī)載入的時(shí)候,會(huì)對static變量進(jìn)行初始化,如果你嘗試不用實(shí)例去訪問非static變量,那么編譯器會(huì)報(bào)錯(cuò),因?yàn)檫@些變量沒有被創(chuàng)建出來,還沒有與實(shí)例關(guān)聯(lián)上。
3.Java中方法重載與方法覆蓋的區(qū)別?
方法重載就是在同一類中的不同參數(shù)的方法,而方法覆蓋就是子類重寫父類的方法:必須參數(shù)一致,返回值一致的方法。
舉個(gè)列子就是:一個(gè)家庭里的你和你弟弟就是對父親的重載(因?yàn)槟愫偷艿艽_實(shí)不是同一人(參數(shù)),但是又都是對父親的繼承下來的);而重寫就相當(dāng)于青出于藍(lán)而勝于藍(lán)。
4.構(gòu)造函數(shù)是?怎么重載構(gòu)造函數(shù)?
構(gòu)造函數(shù)是每個(gè)類都含有的函數(shù),哪怕沒有明顯寫出,也會(huì)默認(rèn)提供的,他是給對象創(chuàng)建時(shí)初始化用的,函數(shù)重載與方法重載類似,只不過參數(shù)不一致而已。
5.接口與抽象類的區(qū)別
接口中的所有方法隱含都是抽象類的,而抽象類可以包含抽象方法與非抽象的方法。
類可以實(shí)現(xiàn)多個(gè)接口,但是只能繼承一個(gè)抽象類;
類如果要實(shí)現(xiàn)一個(gè)接口,就必須實(shí)現(xiàn)其所有方法,類可以不實(shí)現(xiàn)抽的所有抽象方法,當(dāng)然,這種情況下,該類必須聲明成抽象類。
抽象類可以在不提供接口方法實(shí)現(xiàn)的情況下實(shí)現(xiàn)接口;
Java接口中聲明的變量默認(rèn)都是final的,抽象類可以包含非final的變量 ;
接口中的成員函數(shù)默認(rèn)是public,但是抽象可以是public、private、protect的
接口是絕對抽象的,不能被實(shí)例化,抽象類也不能被實(shí)例化,但是可通過父類的引用指向子類的實(shí)例的方法間接的實(shí)現(xiàn)父類的實(shí)例化(因?yàn)樽宇惖膶?shí)例化之前,必須先實(shí)例它的父類(抽象類可以包含構(gòu)造函數(shù)))。
6.值傳遞與引用傳遞
值傳遞就是傳遞了對象的一個(gè)副本,就算改變了對象副本,也不會(huì)影響源對象的值(形參為基本數(shù)據(jù)類型);
引用傳遞就是傳遞了對象的引用,外部對引用對象的改變會(huì)反映到所有的對象身上(行為為引用類型 )。
二:Java線程
7.創(chuàng)建線程的幾種方式?
繼承Thread類;
實(shí)現(xiàn) Runnable接口;
可以使用 Executor 框架來創(chuàng)建線程池可以使用 Executor 框架來創(chuàng)建線程池;
實(shí)現(xiàn)runnable接口這種方式更受歡迎,因?yàn)檫@里不需要繼承Thread類,在實(shí)際當(dāng)中你已經(jīng)繼承別的類,而Java不允許多繼承,所以只能采用實(shí)現(xiàn)runnable接口的方式。
8.概括的解釋下線程的幾種可用狀態(tài)
就緒(Runnable):線程準(zhǔn)備運(yùn)行,不一定就能立馬執(zhí)行;
運(yùn)行中:進(jìn)程正在執(zhí)行線程的代碼;
等待中:線程處于阻塞的狀態(tài),等待外部的處理結(jié)果
睡眠中:線程被強(qiáng)制睡眠
I/O阻塞:等待IO操作完成
同步阻塞:等待獲取鎖?
死亡:線程完成了執(zhí)行
9.同步代碼塊與同步方法的區(qū)別,鎖,死鎖
? ? 每個(gè)對象都可以有一把鎖(synchronized),本質(zhì)都是一樣的,只是顆粒度不一樣而已。監(jiān)視器和鎖在Java中是一塊使用的 ,確保一次只有一個(gè)線程執(zhí)行同步代碼塊,每一個(gè)監(jiān)視器和一個(gè)對象引用相關(guān)聯(lián),線程在獲取鎖之前不允許執(zhí)行同步代碼塊。死鎖就是兩個(gè)線程等待對方執(zhí)行完畢之后,才能繼續(xù)往下執(zhí)行的時(shí)候就發(fā)生死鎖。陷入了無線無限等待的死循環(huán)。避免死循環(huán)就是獲取鎖的順序,并且強(qiáng)制線程按照指定的順序獲取鎖,如果按照順序加載鎖和釋放鎖,就不會(huì)出現(xiàn)死鎖。
請尊重原創(chuàng),轉(zhuǎn)載請聯(lián)系,前行路上的你并不孤單,小蟻君每天都會(huì)陪著你......