提取碼:u6C4?
一、java面試題
熟練掌握java是很關(guān)鍵的,大公司不僅僅要求你會使用幾個api,更多的是要你熟悉源碼實(shí)現(xiàn)原理,甚至要你知道有哪些不足,怎么改進(jìn),還有一些java有關(guān)的一些算法,設(shè)計模式等等。
(一) java基礎(chǔ)面試知識點(diǎn)
java中==和equals和hashCode的區(qū)別
int、char、long各占多少字節(jié)數(shù)
int與integer的區(qū)別
談?wù)剬ava多態(tài)的理解
String、StringBuffer、StringBuilder區(qū)別
什么是內(nèi)部類?內(nèi)部類的作用
抽象類和接口區(qū)別
抽象類的意義
抽象類與接口的應(yīng)用場景
抽象類是否可以沒有方法和屬性?
接口的意義
泛型中extends和super的區(qū)別
父類的靜態(tài)方法能否被子類重寫
進(jìn)程和線程的區(qū)別
final,finally,finalize的區(qū)別
序列化的方式
Serializable 和Parcelable 的區(qū)別
靜態(tài)屬性和靜態(tài)方法是否可以被繼承?是否可以被重寫?以及原因?
靜態(tài)內(nèi)部類的設(shè)計意圖
成員內(nèi)部類、靜態(tài)內(nèi)部類、局部內(nèi)部類和匿名內(nèi)部類的理解,以及項(xiàng)目中的應(yīng)用
談?wù)剬otlin的理解
閉包和局部內(nèi)部類的區(qū)別
string 轉(zhuǎn)換成 integer的方式及原理
(二) java深入源碼級的面試題(有難度)
哪些情況下的對象會被垃圾回收機(jī)制處理掉?
講一下常見編碼方式?
utf-8編碼中的中文占幾個字節(jié);int型幾個字節(jié)?
靜態(tài)代理和動態(tài)代理的區(qū)別,什么場景使用?
Java的異常體系
談?wù)勀銓馕雠c分派的認(rèn)識。
修改對象A的equals方法的簽名,那么使用HashMap存放這個對象實(shí)例的時候,會調(diào)用哪個equals方法?
Java中實(shí)現(xiàn)多態(tài)的機(jī)制是什么?
如何將一個Java對象序列化到文件里?
說說你對Java反射的理解
說說你對Java注解的理解
說說你對依賴注入的理解
說一下泛型原理,并舉例說明
Java中String的了解
String為什么要設(shè)計成不可變的?
Object類的equal和hashCode方法重寫,為什么?
(三) 數(shù)據(jù)結(jié)構(gòu)
常用數(shù)據(jù)結(jié)構(gòu)簡介
并發(fā)集合了解哪些?
列舉java的集合以及集合之間的繼承關(guān)系
集合類以及集合框架
容器類介紹以及之間的區(qū)別(容器類估計很多人沒聽這個詞,Java容器主要可以劃分為4個部分:List列表、Set集合、Map映射、工具類(Iterator迭代器、Enumeration枚舉類、Arrays和Collections),具體的可以看看這篇博文 Java容器類)
List,Set,Map的區(qū)別
List和Map的實(shí)現(xiàn)方式以及存儲方式
HashMap的實(shí)現(xiàn)原理
HashMap數(shù)據(jù)結(jié)構(gòu)?
HashMap源碼理解
HashMap如何put數(shù)據(jù)(從HashMap源碼角度講解)?
HashMap怎么手寫實(shí)現(xiàn)?
ConcurrentHashMap的實(shí)現(xiàn)原理
ArrayMap和HashMap的對比
HashTable實(shí)現(xiàn)原理
TreeMap具體實(shí)現(xiàn)
HashMap和HashTable的區(qū)別
HashMap與HashSet的區(qū)別
HashSet與HashMap怎么判斷集合元素重復(fù)?
集合Set實(shí)現(xiàn)Hash怎么防止碰撞
ArrayList和LinkedList的區(qū)別,以及應(yīng)用場景
數(shù)組和鏈表的區(qū)別
二叉樹的深度優(yōu)先遍歷和廣度優(yōu)先遍歷的具體實(shí)現(xiàn)
堆的結(jié)構(gòu)
堆和樹的區(qū)別
堆和棧在內(nèi)存中的區(qū)別是什么(解答提示:可以從數(shù)據(jù)結(jié)構(gòu)方面以及實(shí)際實(shí)現(xiàn)方面兩個方面去回答)?
什么是深拷貝和淺拷貝
手寫鏈表逆序代碼
講一下對樹,B+樹的理解
講一下對圖的理解
判斷單鏈表成環(huán)與否?
鏈表翻轉(zhuǎn)(即:翻轉(zhuǎn)一個單項(xiàng)鏈表)
合并多個單有序鏈表(假設(shè)都是遞增的)