java后台面試題整理


java基礎

Arrays.sort實現原理和Collection實現原理
foreach和while的區別(編譯之后)
線程池的種類,區別和使用場景
分析線程池的實現原理和線程的調度過程
線程池如何調優
線程池的最大線程數目根據什么確定
動態代理的幾種方式
HashMap的並發問題
了解LinkedHashMap的應用嗎
反射的原理,反射創建類實例的三種方式是什么?
cloneable接口實現原理,淺拷貝or深拷貝
Java NIO使用
hashtable和hashmap的區別及實現原理,hashmap會問到數組索引,hash碰撞怎么解決
arraylist和linkedlist區別及實現原理
反射中,Class.forName和ClassLoader區別
String,Stringbuffer,StringBuilder的區別?
有沒有可能2個不相等的對象有相同的hashcode
簡述NIO的最佳實踐,比如netty,mina
TreeMap的實現原理

JVM相關

類的實例化順序,比如父類靜態數據,構造函數,字段,子類靜態數據,構造函數,字段,他們的執行順序
JVM內存分代
Java 8的內存分代改進
JVM垃圾回收機制,何時觸發MinorGC等操作
jvm中一次完整的GC流程(從ygc到fgc)是怎樣的,重點講講對象如何晉升到老年代,幾種主要的jvm參數等
你知道哪幾種垃圾收集器,各自的優缺點,重點講下cms,g1
新生代和老生代的內存回收策略
Eden和Survivor的比例分配等
深入分析了Classloader,雙親委派機制
JVM的編譯優化
對Java內存模型的理解,以及其在並發中的應用
指令重排序,內存柵欄等
OOM錯誤,stackoverflow錯誤,permgen space錯誤
JVM常用參數
tomcat結構,類加載器流程
volatile的語義,它修飾的變量一定線程安全嗎
g1和cms區別,吞吐量優先和響應優先的垃圾收集器選擇
說一說你對環境變量classpath的理解?如果一個類不在classpath下,為什么會拋出ClassNotFoundException異常,如果在不改變這個類路徑的前期下,怎樣才能正確加載這個類?
說一下強引用、軟引用、弱引用、虛引用以及他們之間和gc的關系

JUC/並發相關

ThreadLocal用過么,原理是什么,用的時候要注意什么
Synchronized和Lock的區別
synchronized 的原理,什么是自旋鎖,偏向鎖,輕量級鎖,什么叫可重入鎖,什么叫公平鎖和非公平鎖
concurrenthashmap具體實現及其原理,jdk8下的改版
用過哪些原子類,他們的參數以及原理是什么
cas是什么,他會產生什么問題(ABA問題的解決,如加入修改次數、版本號)
如果讓你實現一個並發安全的鏈表,你會怎么做
簡述ConcurrentLinkedQueue和LinkedBlockingQueue的用處和不同之處
簡述AQS的實現原理
countdowlatch和cyclicbarrier的用法,以及相互之間的差別?
concurrent包中使用過哪些類?分別說說使用在什么場景?為什么要使用?
LockSupport工具
Condition接口及其實現原理
Fork/Join框架的理解
jdk8的parallelStream的理解
分段鎖的原理,鎖力度減小的思考

Spring

Spring AOP與IOC的實現原理
Spring的beanFactory和factoryBean的區別
為什么CGlib方式可以對接口的實現進行代理?
RMI與代理模式
Spring的事務隔離級別,實現原理
對Spring的理解,非單例注入的原理?它的生命周期?循環注入的原理,aop的實現原理,說說aop中的幾個術語,它們是怎么相互工作的?
Mybatis的底層實現原理
MVC框架原理,他們都是怎么做url路由的
spring boot特性,優勢,適用場景等
quartz和timer對比
spring的controller是單例還是多例,怎么保證並發的安全

分布式相關

Dubbo的底層實現原理和機制
描述一個服務從發布到被消費的詳細過程
分布式系統怎么做服務治理
接口的冪等性的概念
消息中間件如何解決消息丟失問題
Dubbo的服務請求失敗怎么處理
重連機制會不會造成錯誤
對分布式事務的理解
如何實現負載均衡,有哪些算法可以實現?
Zookeeper的用途,選舉的原理是什么?
數據的垂直拆分水平拆分。
zookeeper原理和適用場景
zookeeper watch機制
redis/zk節點宕機如何處理
分布式集群下如何做到唯一序列號
如何做一個分布式鎖
用過哪些MQ,怎么用的,和其他mq比較有什么優缺點,MQ的連接是線程安全的嗎
MQ系統的數據如何保證不丟失
列舉出你能想到的數據庫分庫分表策略;分庫分表后,如何解決全表查詢的問題。

算法&數據結構&設計模式

海量url去重類問題(布隆過濾器)
數組和鏈表數據結構描述,各自的時間復雜度
二叉樹遍歷
快速排序
BTree相關的操作
在工作中遇到過哪些設計模式,是如何應用的
hash算法的有哪幾種,優缺點,使用場景
什么是一致性hash
paxos算法
在裝飾器模式和代理模式之間,你如何抉擇,請結合自身實際情況聊聊
代碼重構的步驟和原因,如果理解重構到模式?

數據庫

MySQL InnoDB存儲的文件結構
索引樹是如何維護的?
數據庫自增主鍵可能的問題
MySQL的幾種優化
mysql索引為什么使用B+樹
數據庫鎖表的相關處理
索引失效場景
高並發下如何做到安全的修改同一行數據,樂觀鎖和悲觀鎖是什么,INNODB的行級鎖有哪2種,解釋其含義
數據庫會死鎖嗎,舉一個死鎖的例子,mysql怎么解決死鎖

Redis&緩存相關

Redis的並發競爭問題如何解決
了解Redis事務的CAS操作嗎
緩存機器增刪如何對系統影響最小,一致性哈希的實現
Redis持久化的幾種方式,優缺點是什么,怎么實現的
Redis的緩存失效策略
緩存穿透的解決辦法
redis集群,高可用,原理
mySQL里有2000w數據,redis中只存20w的數據,如何保證redis中的數據都是熱點數據
用Redis和任意語言實現一段惡意登錄保護的代碼,限制1小時內每用戶Id最多只能登錄5次
redis的數據淘汰策略

網絡相關

http1.0和http1.1有什么區別
TCP/IP協議
TCP三次握手和四次揮手的流程,為什么斷開連接要4次,如果握手只有兩次,會出現什么
TIME_WAIT和CLOSE_WAIT的區別
說說你知道的幾種HTTP響應碼
當你用瀏覽器打開一個鏈接的時候,計算機做了哪些工作步驟
TCP/IP如何保證可靠性,數據包有哪些數據組成
長連接與短連接
Http請求get和post的區別以及數據包格式
簡述tcp建立連接3次握手,和斷開連接4次握手的過程;關閉連接時,出現TIMEWAIT過多是由什么原因引起,是出現在主動斷開方還是被動斷開方。

其他

maven解決依賴沖突,快照版和發行版的區別
Linux下IO模型有幾種,各自的含義是什么
實際場景問題,海量登錄日志如何排序和處理SQL操作,主要是索引和聚合函數的應用
實際場景問題解決,典型的TOP K問題
線上bug處理流程
如何從線上日志發現問題
linux利用哪些命令,查找哪里出了問題(例如io密集任務,cpu過度)
場景問題,有一個第三方接口,有很多個線程去調用獲取數據,現在規定每秒鍾最多有10個線程同時調用它,如何做到。
用三個線程按順序循環打印abc三個字母,比如abcabcabc。
常見的緩存策略有哪些,你們項目中用到了什么緩存系統,如何設計的
設計一個秒殺系統,30分鍾沒付款就自動關閉交易(並發會很高)
請列出你所了解的性能測試工具
后台系統怎么防止請求重復提交?



作者:jsondream
鏈接:http://www.jianshu.com/p/f5dee1306d0d
來源:簡書
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。

問題答案正在整理中


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM