JavaBAT面試精華彙總(內附答案)

這些題目是去百度、小米、樂視、美團、58、獵豹、360、新浪、搜狐等一線互聯網公司面試被問到的題目,熟悉本文中列出的知識點會大大增加通過前兩輪技術面試的機率。

一.java基礎面試知識點

java中==和equals和hashCode的區別

int、char、long各佔多少字節數

int與integer的區別

探探對java多態的理解

String、StringBuffer、StringBuilder區別

什麼是內部類?內部類的作用

抽象類和接口區別

抽象類的意義

抽象類與接口的應用場景

抽象類是否可以沒有方法和屬性?

接口的意義

泛型中extends和super的區別

父類的靜態方法能否被子類重寫

進程和線程的區別

final,finally,finalize的區別

序列化的方式

Serializable 和Parcelable 的區別

靜態屬性和靜態方法是否可以被繼承?是否可以被重寫?以及原因?

靜態內部類的設計意圖

成員內部類、靜態內部類、局部內部類和匿名內部類的理解,以及項目中的應用

談談對kotlin的理解

閉包和局部內部類的區別

string 轉換成 integer的方式及原理

二.java深入面試題

哪些情況下的對象會被垃圾回收機制處理掉?

講一下常見編碼方式?

utf-8編碼中的中文佔幾個字節;int型幾個字節?

靜態代理和動態代理的區別,什麼場景使用?

Java的異常體系

談談你對解析與分派的認識。

修改對象A的equals方法的簽名,那麼使用HashMap存放這個對象實例的時候,會調用哪個equals方法?

Java中實現多態的機制是什麼?

如何將一個Java對象序列化到文件裏?

說說你對Java反射的理解

說說你對Java註解的理解

說說你對依賴注入的理解

說一下泛型原理,並舉例說明

Java中String的瞭解

String爲什麼要設計成不可變的?

Object類的equal和hashCode方法重寫,爲什麼?

三.數據結構

常用數據結構簡介

併發集合瞭解哪些?

列舉java的集合以及集合之間的繼承關係

集合類以及集合框架

容器類介紹以及之間的區別(容器類估計很多人沒聽這個詞,Java容器主要可以劃分爲4個部分:List列表、Set集合、Map映射、工具類(Iterator迭代器、Enumeration枚舉類、Arrays和Collections),具體的可以看看這篇博文 Java容器類)

List,Set,Map的區別

List和Map的實現方式以及存儲方式

HashMap的實現原理

HashMap數據結構?

HashMap源碼理解

HashMap如何put數據(從HashMap源碼角度講解)?

HashMap怎麼手寫實現?

ConcurrentHashMap的實現原理

ArrayMap和HashMap的對比

HashTable實現原理

TreeMap具體實現

HashMap和HashTable的區別

HashMap與HashSet的區別

HashSet與HashMap怎麼判斷集合元素重複?

集合Set實現Hash怎麼防止碰撞

ArrayList和LinkedList的區別,以及應用場景

數組和鏈表的區別

二叉樹的深度優先遍歷和廣度優先遍歷的具體實現

堆的結構

堆和樹的區別

堆和棧在內存中的區別是什麼(解答提示:可以從數據結構方面以及實際實現方面兩個方面去回答)?

什麼是深拷貝和淺拷貝

手寫鏈表逆序代碼

講一下對樹,B+樹的理解

講一下對圖的理解

判斷單鏈表成環與否?

鏈表翻轉(即:翻轉一個單項鍊表)

合併多個單有序鏈表(假設都是遞增的)

四.線程、多線程和線程池

開啓線程的三種方式?

線程和進程的區別?

爲什麼要有線程,而不是僅僅用進程?

run()和start()方法區別

如何控制某個方法允許併發訪問線程的個數?

在Java中wait和seelp方法的不同;

談談wait/notify關鍵字的理解

什麼導致線程阻塞?

線程如何關閉?

講一下java中的同步的方法

數據一致性如何保證?

如何保證線程安全?

如何實現線程同步?

兩個進程同時要求寫或者讀,能不能實現?如何防止進程的同步?

線程間操作List

Java中對象的生命週期

Synchronized用法

synchronize的原理

談談對Synchronized關鍵字,類鎖,方法鎖,重入鎖的理解

static synchronized 方法的多線程訪問和作用

同一個類裏面兩個synchronized方法,兩個線程同時訪問的問題

volatile的原理

談談volatile關鍵字的用法

談談volatile關鍵字的作用

談談NIO的理解

synchronized 和volatile 關鍵字的區別

synchronized與Lock的區別

ReentrantLock 、synchronized和volatile比較

ReentrantLock的內部實現

lock原理

死鎖的四個必要條件?

怎麼避免死鎖?

對象鎖和類鎖是否會互相影響?

什麼是線程池,如何使用?

Java的併發、多線程、線程模型

談談對多線程的理解

多線程有什麼要注意的問題?

談談你對併發編程的理解並舉例說明

談談你對多線程同步機制的理解?

如何保證多線程讀寫文件的安全?

多線程斷點續傳原理

斷點續傳的實現

五.算法

排序算法有哪些?

最快的排序算法是哪個?

手寫一個冒泡排序

手寫快速排序代碼

快速排序的過程、時間複雜度、空間複雜度

手寫堆排序

堆排序過程、時間複雜度及空間複雜度

寫出你所知道的排序算法及時空複雜度,穩定性

二叉樹給出根節點和目標節點,找出從根節點到目標節點的路徑

給阿里2萬多名員工按年齡排序應該選擇哪個算法?

GC算法(各種算法的優缺點以及應用場景)

蟻羣算法與蒙特卡洛算法

子串包含問題(KMP 算法)寫代碼實現

一個無序,不重複數組,輸出N個元素,使得N個元素的和相加爲M,給出時間複雜度、空間複雜度。手寫算法

萬億級別的兩個URL文件A和B,如何求出A和B的差集C(提示:Bit映射->hash分組->多文件讀寫效率->磁盤尋址以及應用層面對尋址的優化)

六.數據庫相關

MySQL InnoDB、Mysaim的特點?

樂觀鎖和悲觀鎖的區別?

數據庫隔離級別是什麼?有什麼作用?

MySQL主備同步的基本原理。

select * from table t where size > 10 group by size order by size的sql語句執行順序?

如何優化數據庫性能(索引、分庫分表、批量操作、分頁算法、升級硬盤SSD、業務優化、主從部署)

SQL什麼情況下不會使用索引(不包含,不等於,函數)

一般在什麼字段上建索引(過濾數據最多的字段)

如何從一張表中查出name字段不包含“XYZ”的所有行?

MySQL,B+索引實現,行鎖實現,SQL優化

Redis,RDB和AOF,如何做高可用、集羣

如何解決高併發減庫存問題

mysql存儲引擎中索引的實現機制;

數據庫事務的幾種粒度;

行鎖,表鎖;樂觀鎖,悲觀鎖

七.Redis等緩存系統中間件

列舉一個常用的Redis客戶端的併發模型。

HBase如何實現模糊查詢?

列舉一個常用的消息中間件,如果消息要保序如何實現?

如何實現一個Hashtable?你的設計如何考慮Hash衝突?如何優化?

分佈式緩存,一致性hash

LRU算法,slab分配,如何減少內存碎片

如何解決緩存單機熱點問題

什麼是布隆過濾器,其實現原理是? False positive指的是?

memcache與redis的區別

zookeeper有什麼功能,選舉算法如何進行

map/reduce過程,如何用map/reduce實現兩個數據源的聯合統計

“如果程序員對職場感到迷茫,對眼下的舒適感到不安,我建議出去面試,不見得要走,但是你要出去,聽聽市場對自己的評價。”

【文章彩蛋】

爲了解決小夥伴們的燃眉之急,小編特地爲大家整理了一些Java相關的面試題,

可以關注!轉發!私信“03”!獲取!

後期也會不斷更新添加新的面試題,希望可以幫助到大家。

JavaBAT面試精華彙總(內附答案)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章