2023年高薪Java面試題_第1頁
2023年高薪Java面試題_第2頁
2023年高薪Java面試題_第3頁
2023年高薪Java面試題_第4頁
2023年高薪Java面試題_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

2023高薪Java面試題

Switch能否用string做參數(shù)?

1、在Java7之前,switch只能支持byte,short,char,int或者其對應(yīng)的封裝類以及Enum類型。在JAVA7中,String支持被加上了。

equals與==的區(qū)分:

1、==是推斷兩個(gè)變量或?qū)嵗遣皇侵赶蛲粋€(gè)內(nèi)存空間

2、equals是推斷兩個(gè)變量或?qū)嵗赶虻膬?nèi)存空間的值是不是一樣

Object有哪些公用方法?

1、方法equals測試的是兩個(gè)對象是否相等

2、方法clone進(jìn)展對象拷貝

3、方法getClass返回和當(dāng)前對象相關(guān)的Class對象

4、方法notify,notifyall,wait都是用來對給定對象進(jìn)展線程同步的

Java的四種引用,強(qiáng)弱軟虛,用到的場景

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

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

3、弱引用:具有弱引用的對象擁有的生命周期更短暫。由于當(dāng)JVM進(jìn)展垃圾回收,一旦發(fā)覺弱引用對象,無論當(dāng)前內(nèi)存空間是否充分,都會將弱引用回收。不過由于垃圾回收器是一個(gè)優(yōu)先級較低的線程,所以并不肯定能快速發(fā)覺弱引用對象

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

Hashcode的作用,與equal有什么區(qū)分

1、同樣用于鑒定2個(gè)對象是否相等的,java集合中有l(wèi)ist和set兩類,其中set不允許元素重復(fù)實(shí)現(xiàn),那個(gè)這個(gè)不允許重復(fù)實(shí)現(xiàn)的方法,假如用equal去比擬的話,假如存在1000個(gè)元素,你new一個(gè)新的元素出來,需要去調(diào)用1000次equal去逐個(gè)和他們比擬是否是同一個(gè)對象,這樣會大大降低效率。hashcode實(shí)際上是返回對象的存儲地址,假如這個(gè)位置上沒有元素,就把元素直接存儲在上面,假如這個(gè)位置上已經(jīng)存在元素,這個(gè)時(shí)候才去調(diào)用equal方法與新元素進(jìn)展比擬,一樣的話就不存了,散列到其他地址上

String、StringBuffer與StringBuilder的區(qū)分

1、String類型和StringBuffer類型的主要性能區(qū)分其實(shí)在于String是不行變的對象

2、StringBuffer和StringBuilder底層是char[]數(shù)組實(shí)現(xiàn)的

3、StringBuffer是線程安全的,而StringBuilder是線程擔(dān)心全的

Override和Overload的含義去區(qū)分

1、Overload顧名思義是重新加載,它可以表現(xiàn)類的多態(tài)性,可以是函數(shù)里面可以有一樣的函數(shù)名但是參數(shù)名、返回值、類型不能一樣;或者說可以轉(zhuǎn)變參數(shù)、類型、返回值但是函數(shù)名字依舊不變。

2、就是ride(重寫)的意思,在子類繼承父類的時(shí)候子類中可以定義某方法與其父類有一樣的名稱和參數(shù),當(dāng)子類在調(diào)用這一函數(shù)時(shí)自動調(diào)用子類的方法,而父類相當(dāng)于被掩蓋(重寫)了。

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

1、一個(gè)類只能繼承單個(gè)類,但是可以實(shí)現(xiàn)多個(gè)接口

2、接口強(qiáng)調(diào)特定功能的實(shí)現(xiàn),而抽象類強(qiáng)調(diào)所屬關(guān)系

3、抽象類中的全部方法并不肯定要是抽象的,你可以選擇在抽象類中實(shí)現(xiàn)一些根本的方法。而接口要求全部的方法都必需是抽象的

解析XML的幾種方式的原理與特點(diǎn):DOM、SAX、PULL

1、DOM:消耗內(nèi)存:先把xml文檔都讀到內(nèi)存中,然后再用DOMAPI來訪問樹形構(gòu)造,并獵取數(shù)據(jù)。這個(gè)寫起來很簡潔,但是很消耗內(nèi)存。要是數(shù)據(jù)過大,手機(jī)不夠牛逼,可能手機(jī)直接死機(jī)

2、SAX:解析效率高,占用內(nèi)存少,基于大事驅(qū)動的:更加簡潔地說就是對文檔進(jìn)展挨次掃描,當(dāng)掃描到文檔(document)開頭與完畢、元素(element)開頭與完畢、文檔(document)完畢等地方時(shí)通知大事處理函數(shù),由大事處理函數(shù)做相應(yīng)動作,然后連續(xù)同樣的掃描,直至文檔完畢。

3、SAX:與SAX類似,也是基于大事驅(qū)動,我們可以調(diào)用它的next()方法,來獵取下一個(gè)解析大事(就是開頭文檔,完畢文檔,開頭標(biāo)簽,完畢標(biāo)簽),當(dāng)處于某個(gè)元素時(shí)可以調(diào)用XmlPullParser的getAttributte()方法來獵取屬性的值,也可調(diào)用它的nextText()獵取本節(jié)點(diǎn)的值。

wait()和sleep()的區(qū)分

1、sleep來自Thread類,和wait來自O(shè)bject類

2、調(diào)用sleep()方法的過程中,線程不會釋放對象鎖。而調(diào)用wait方法線程會釋放對象鎖

3、sleep睡眠后不出讓系統(tǒng)資源,wait讓出系統(tǒng)資源其他線程可以占用CPU

4、sleep(milliseconds)需要指定一個(gè)睡眠時(shí)間,時(shí)間一到會自動喚醒

JAVA多態(tài)的實(shí)現(xiàn)原理

1、抽象的來講,多態(tài)的”意思就是同一消息可以依據(jù)發(fā)送對象的不同而采納多種不同的行為方式。(發(fā)送消息就是函數(shù)調(diào)用)

2、實(shí)現(xiàn)的原理是動態(tài)綁定,程序調(diào)用的方法在運(yùn)行期才動態(tài)綁定,追溯源碼可以發(fā)覺,JVM通過參數(shù)的自動轉(zhuǎn)型來找到適宜的方法。

JAVA中堆和棧的區(qū)分,說下java的內(nèi)存機(jī)制

1、根本數(shù)據(jù)類型比變量和對象的引用都是在棧安排的

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

3、類變量(static修飾的變量),程序在一加載的時(shí)候就在堆中為類變量安排內(nèi)存,堆中的內(nèi)存地址存放在棧中

4、實(shí)例變量:當(dāng)你使用java關(guān)鍵字new的時(shí)候,系統(tǒng)在堆中開拓并不肯定是連續(xù)的空間安排給變量,是依據(jù)零散的堆內(nèi)存地址,通過哈希算法換算為一長串?dāng)?shù)字以表征這個(gè)變量在堆中的物理位置”,實(shí)例變量的生命周期--當(dāng)實(shí)例變量的引用喪失后,將被GC(垃圾回收器)列入可回收“名單”中,但并不是立刻就釋放堆中內(nèi)存

5、局部變量:由聲明在某方法,或某代碼段里(比方for循環(huán)),執(zhí)行到它的時(shí)候在棧中開拓內(nèi)存,當(dāng)局部變量一但脫離作用域,內(nèi)存馬上釋放

講講Java中的集合有多少種,區(qū)分是什么?

1、ArrayList、LinkedList、Vector的區(qū)分:ArrayList和Vector底層是采納數(shù)組方式存儲數(shù)據(jù),Vector由于使用了synchronized方法(線程安全)所以性能上比ArrayList要差,LinkedList使用雙向鏈表實(shí)現(xiàn)存儲,隨機(jī)存取比擬慢

2、HashMap的底層源碼實(shí)現(xiàn):當(dāng)我們往HashMap中put元素的時(shí)候,先依據(jù)key的hashCode重新計(jì)算hash值,依據(jù)hash值得到這個(gè)元素在數(shù)組中的位置(即下標(biāo)),假如數(shù)組該位置上已經(jīng)存放有其他元素了,那么在這個(gè)位置上的元素將以鏈表的形式存放,新參加的放在鏈頭,最先參加的放在鏈尾。假如數(shù)組該位置上沒有元素,就直接將該元素放到此數(shù)組中的該位置上。

3、Fail-Fast機(jī)制:在使用迭代器的過程中有其他線程修改了map,那么將拋出ConcurrentModificationException,這就是所謂fail-fast機(jī)制。這一機(jī)制在源碼中的實(shí)現(xiàn)是通過modCount域,modCount顧名思義就是修改次數(shù),對HashMap內(nèi)容的修改都將增加這個(gè)值,那么在迭代器初始化過程中會將這個(gè)值賦給迭代器的expectedModCount。在迭代過程中,推斷modCount跟expectedModCount是否相等,假如不相等就表示已經(jīng)有其他線程修改了Map.

百度面試題

finalfinallyfinalize三者的區(qū)分。

1、finalize是一個(gè)方法,而且它是Object類中的一個(gè)方法。當(dāng)垃圾收集器在確定這個(gè)對象沒有被引用時(shí)調(diào)用對象的finalize方法。它的作用是為GC清理對象之前做一些必要的清理工作(如輸入/輸出連接的對象的fina

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論