【面試必備】常見Java面試題大綜合

1、Java基礎

一、Arrays.sort實現原理和Collections.sort實現原理
答:Collections.sort方法底層會調用Arrays.sort方法,底層實現都是TimeSort實現的。TimSort算法就是找到已經排好序數據的子序列,而後對剩餘部分排序,而後合併起來.
二、foreach和while的區別(編譯以後) 線程池的種類,區別和使用場景
三、分析線程池的實現原理和線程的調度過程
四、線程池如何調優
五、線程池的最大線程數目根據什麼肯定mysql


六、動態代理的幾種方式
七、HashMap的併發問題
八、瞭解LinkedHashMap的應用嗎
九、反射的原理,反射建立類實例的三種方式是什麼?
十、cloneable接口實現原理,淺拷貝or深拷貝

十一、Java NIO使用
十二、hashtable和hashmap的區別及實現原理,hashmap會問到數組索引,hash碰撞怎麼解決
1三、arraylist和linkedlist區別及實現原理
1四、反射中,Class.forName和ClassLoader區別
1五、String,Stringbuffer,StringBuilder的區別?

1六、有沒有可能2個不相等的對象有相同的hashcode
1七、簡述NIO的最佳實踐,好比netty,mina
1八、TreeMap的實現原理linux


2、JVM相關

一、類的實例化順序,好比父類靜態數據,構造函數,字段,子類靜態數據,構造函數,字段,他們的執行順序
二、JVM內存分代
三、Java 8的內存分代改進
四、JVM垃圾回收機制,什麼時候觸發MinorGC等操做
五、jvm中一次完整的GC流程(從ygc到fgc)是怎樣的,重點講講對象如何晉升到老年代,幾種主要的jvm參數等面試


六、你知道哪幾種垃圾收集器,各自的優缺點,重點講下cms,g1
七、新生代和老生代的內存回收策略
八、Eden和Survivor的比例分配等
九、深刻分析了Classloader,雙親委派機制
十、JVM的編譯優化

十一、對Java內存模型的理解,以及其在併發中的應用
十二、指令重排序,內存柵欄等
1三、OOM錯誤,stackoverflow錯誤,permgen space錯誤
1四、JVM經常使用參數
1五、tomcat結構,類加載器流程

1六、volatile的語義,它修飾的變量必定線程安全嗎
1七、g1和cms區別,吞吐量優先和響應優先的垃圾收集器選擇
1八、說一說你對環境變量classpath的理解?若是一個類不在classpath下,爲何會拋出ClassNotFoundException異常,若是在不改變這個類路徑的前期下,怎樣才能正確加載這個類?
1九、說一下強引用、軟引用、弱引用、虛引用以及他們之間和gc的關係
20、常見Java面試題大綜合,很是值得一看,面試必備!!!redis

 


3、JUC/併發相關算法


一、ThreadLocal用過麼,原理是什麼,用的時候要注意什麼

二、Synchronized和Lock的區別
三、synchronized 的原理,什麼是自旋鎖,偏向鎖,輕量級鎖,什麼叫可重入鎖,什麼叫公平鎖和非公平鎖
四、concurrenthashmap具體實現及其原理,jdk8下的改版
五、用過哪些原子類,他們的參數以及原理是什麼

六、cas是什麼,他會產生什麼問題(ABA問題的解決,如加入修改次數、版本號)
七、若是讓你實現一個併發安全的鏈表,你會怎麼作
八、簡述ConcurrentLinkedQueue和LinkedBlockingQueue的用處和不一樣之處
九、簡述AQS的實現原理
十、countdowlatch和cyclicbarrier的用法,以及相互之間的差異?spring


十一、concurrent包中使用過哪些類?分別說說使用在什麼場景?爲何要使用?
十二、LockSupport工具
1三、Condition接口及其實現原理
1四、Fork/Join框架的理解
1五、jdk8的parallelStream的理解sql


1六、分段鎖的原理,鎖力度減少的思考
1七、常見Java面試題大綜合,很是值得一看,面試必備!!!

4、Spring數據庫


一、Spring AOP與IOC的實現原理

二、Spring的beanFactory和factoryBean的區別
三、爲何CGlib方式能夠對接口實現代理?
四、RMI與代理模式
五、Spring的事務隔離級別,實現原理

六、對Spring的理解,非單例注入的原理?它的生命週期?循環注入的原理,aop的實現原理,說說aop中的幾個術語,它們是怎麼相互工做的?
七、Mybatis的底層實現原理
八、MVC框架原理,他們都是怎麼作url路由的
九、spring boot特性,優點,適用場景等
十、quartz和timer對比
十一、spring的controller是單例仍是多例,怎麼保證併發的安全設計模式


5、分佈式相關數組


一、Dubbo的底層實現原理和機制

二、描述一個服務從發佈到被消費的詳細過程
三、分佈式系統怎麼作服務治理
四、接口的冪等性的概念
五、消息中間件如何解決消息丟失問題


六、Dubbo的服務請求失敗怎麼處理
七、重連機制會不會形成錯誤
八、對分佈式事務的理解
九、如何實現負載均衡,有哪些算法能夠實現?
十、Zookeeper的用途,選舉的原理是什麼?

十一、數據的垂直拆分水平拆分。
十二、zookeeper原理和適用場景
1三、zookeeper watch機制
1四、redis/zk節點宕機如何處理
1五、分佈式集羣下如何作到惟一序列號

1六、如何作一個分佈式鎖
1七、用過哪些MQ,怎麼用的,和其餘mq比較有什麼優缺點,MQ的鏈接是線程安全的嗎
1八、MQ系統的數據如何保證不丟失
1九、列舉出你能想到的數據庫分庫分表策略;分庫分表後,如何解決全表查詢的問題。
20、算法&數據結構&設計模式


2一、海量url去重類問題(布隆過濾器)
2二、數組和鏈表數據結構描述,各自的時間複雜度
2三、二叉樹遍歷
2四、快速排序

6、BTree相關的操做


一、在工做中遇到過哪些設計模式,是如何應用的

二、hash算法的有哪幾種,優缺點,使用場景
三、什麼是一致性hash
四、paxos算法
五、在裝飾器模式和代理模式之間,你如何抉擇,請結合自身實際狀況聊聊

六、代碼重構的步驟和緣由,若是理解重構到模式?
七、數據庫
八、MySQL InnoDB存儲的文件結構
九、索引樹是如何維護的?
十、數據庫自增主鍵可能的問題
十一、MySQL的幾種優化

十二、mysql索引爲何使用B+樹
1三、數據庫鎖表的相關處理
1四、索引失效場景
1五、高併發下如何作到安全的修改同一行數據,樂觀鎖和悲觀鎖是什麼,INNODB的行級鎖有哪2種,解釋其含義
1六、數據庫會死鎖嗎,舉一個死鎖的例子,mysql怎麼解決死鎖

7、Redis緩存相關


一、Redis的併發競爭問題如何解決了解Redis事務的CAS操做嗎

二、緩存機器增刪如何對系統影響最小,一致性哈希的實現
三、Redis持久化的幾種方式,優缺點是什麼,怎麼實現的
四、Redis的緩存失效策略
五、緩存穿透的解決辦法

六、redis集羣,高可用,原理
七、mySQL裏有2000w數據,redis中只存20w的數據,如何保證redis中的數據都是熱點數據
八、用Redis和任意語言實現一段惡意登陸保護的代碼,限制1小時內每用戶Id最多隻能登陸5次
九、redis的數據淘汰策略

8、網絡相關


一、http1.0和http1.1有什麼區別

二、TCP/IP協議
三、TCP三次握手和四次揮手的流程,爲何斷開鏈接要4次,若是握手只有兩次,會出現什麼
四、TIME_WAIT和CLOSE_WAIT的區別
五、說說你知道的幾種HTTP響應碼

六、當你用瀏覽器打開一個連接的時候,計算機作了哪些工做步驟
七、TCP/IP如何保證可靠性,數據包有哪些數據組成
八、長鏈接與短鏈接
九、Http請求get和post的區別以及數據包格式
十、簡述tcp創建鏈接3次握手,和斷開鏈接4次握手的過程;關閉鏈接時,出現TIMEWAIT過可能是由什麼緣由引發,是出如今主動斷開方仍是被動斷開方。

9、其餘


一、maven解決依賴衝突,快照版和發行版的區別

二、Linux下IO模型有幾種,各自的含義是什麼
三、實際場景問題,海量登陸日誌如何排序和處理SQL操做,主要是索引和聚合函數的應用
四、實際場景問題解決,典型的TOP K問題
五、線上bug處理流程

六、如何從線上日誌發現問題
七、linux利用哪些命令,查找哪裏出了問題(例如io密集任務,cpu過分)
八、場景問題,有一個第三方接口,有不少個線程去調用獲取數據,如今規定每秒鐘最多有10個線程同時調用它,如何作到。
九、用三個線程按順序循環打印abc三個字母,好比abcabcabc。
十、常見的緩存策略有哪些,大家項目中用到了什麼緩存系統,如何設計的
十一、設計一個秒殺系統,30分鐘沒付款就自動關閉交易(併發會很高)
十二、請列出你所瞭解的性能測試工具
1三、後臺系統怎麼防止請求重複提交?
1四、有多個相同的接口,我想客戶端同時請求,而後只須要在第一個請求返回結果的時候返回給客戶端。

相關文章
相關標籤/搜索