此套面試題適用于Java開發(fā)的各個階段面試,不過更偏向初級和中級開發(fā)人員!由于每一個問題的答案不唯一且都可以在網(wǎng)上搜索到答案,這里只給出問題,不列出參考答案,有興趣的可以留言討論,也歡迎大家的補充!
面向?qū)ο蟮奶卣鳎豪^承、封裝和多態(tài)
final, finally, finalize 的區(qū)別
Exception、Error、運行時異常與一般異常有何異同
請寫出5種常見到的runtime exception
int 和 Integer 有什么區(qū)別,Integer的值緩存范圍
包裝類,裝箱和拆箱
String、StringBuilder、StringBuffer
重載和重寫的區(qū)別
抽象類和接口有什么區(qū)別
說說反射的用途及實現(xiàn)
說說自定義注解的場景及實現(xiàn)
HTTP請求的GET與POST方式的區(qū)別
Session與Cookie區(qū)別
列出自己常用的JDK包
MVC設(shè)計思想
equals與==的區(qū)別
hashCode和equals方法的區(qū)別與聯(lián)系
什么是Java序列化和反序列化,如何實現(xiàn)Java序列化?或者請解釋Serializable 接口的作用
Object類中常見的方法,為什么wait notify會放在Object里邊?
Java的平臺無關(guān)性如何體現(xiàn)出來的
JDK和JRE的區(qū)別
Java 8有哪些新特性
List 和 Set 區(qū)別
Set和hashCode以及equals方法的聯(lián)系
List 和 Map 區(qū)別
Arraylist 與 LinkedList 區(qū)別
ArrayList 與 Vector 區(qū)別
HashMap 和 Hashtable 的區(qū)別
HashSet 和 HashMap 區(qū)別
HashMap 和 ConcurrentHashMap 的區(qū)別
HashMap 的工作原理及代碼實現(xiàn),什么時候用到紅黑樹
多線程情況下HashMap死循環(huán)的問題
HashMap出現(xiàn)Hash DOS攻擊的問題
ConcurrentHashMap 的工作原理及代碼實現(xiàn),如何統(tǒng)計所有的元素個數(shù)
手寫簡單的HashMap
看過那些Java集合類的源碼
1.3、進程和線程
線程和進程的概念、并行和并發(fā)的概念
創(chuàng)建線程的方式及實現(xiàn)
進程間通信的方式
說說 CountDownLatch、CyclicBarrier 原理和區(qū)別
說說 Semaphore 原理
說說 Exchanger 原理
ThreadLocal 原理分析,ThreadLocal為什么會出現(xiàn)OOM,出現(xiàn)的深層次原理
講講線程池的實現(xiàn)原理
線程池的幾種實現(xiàn)方式
線程的生命周期,狀態(tài)是如何轉(zhuǎn)移的
說說線程安全問題,什么是線程安全,如何保證線程安全
重入鎖的概念,重入鎖為什么可以防止死鎖
產(chǎn)生死鎖的四個條件(互斥、請求與保持、不剝奪、循環(huán)等待)
如何檢查死鎖(通過jConsole檢查死鎖)
volatile 實現(xiàn)原理(禁止指令重排、刷新內(nèi)存)
synchronized 實現(xiàn)原理(對象監(jiān)視器)
synchronized 與 lock 的區(qū)別
AQS同步隊列
CAS無鎖的概念、樂觀鎖和悲觀鎖
常見的原子操作類
什么是ABA問題,出現(xiàn)ABA問題JDK是如何解決的
樂觀鎖的業(yè)務(wù)場景及實現(xiàn)方式
Java 8并法包下常見的并發(fā)類
偏向鎖、輕量級鎖、重量級鎖、自旋鎖的概念
JVM運行時內(nèi)存區(qū)域劃分
內(nèi)存溢出OOM和堆棧溢出SOE的示例及原因、如何排查與解決
如何判斷對象是否可以回收或存活
常見的GC回收算法及其含義
常見的JVM性能監(jiān)控和故障處理工具類:jps、jstat、jmap、jinfo、jconsole等
JVM如何設(shè)置參數(shù)
JVM性能調(diào)優(yōu)
類加載器、雙親委派模型、一個類的生命周期、類是如何加載到JVM中的
類加載的過程:加載、驗證、準備、解析、初始化
強引用、軟引用、弱引用、虛引用
Java內(nèi)存模型JMM
常見的設(shè)計模式
設(shè)計模式的的六大原則及其含義
常見的單例模式以及各種實現(xiàn)方式的優(yōu)缺點,哪一種最好,手寫常見的單利模式
設(shè)計模式在實際場景中的應(yīng)用
Spring中用到了哪些設(shè)計模式
MyBatis中用到了哪些設(shè)計模式
你項目中有使用哪些設(shè)計模式
說說常用開源框架中設(shè)計模式使用分析
動態(tài)代理很重要?。?!
1.7、數(shù)據(jù)結(jié)構(gòu)
樹(二叉查找樹、平衡二叉樹、紅黑樹、B樹、B+樹)
深度有限算法、廣度優(yōu)先算法
克魯斯卡爾算法、普林母算法、迪克拉斯算法
什么是一致性Hash及其原理、Hash環(huán)問題
常見的排序算法和查找算法:快排、折半查找、堆排序等
BIO、NIO、AIO的概念
什么是長連接和短連接
Http1.0和2.0相比有什么區(qū)別,可參考《Http 2.0》
Https的基本概念
三次握手和四次揮手、為什么揮手需要四次
從游覽器中輸入URL到頁面加載的發(fā)生了什么?可參考《從輸入URL到頁面加載發(fā)生了什么》
二、數(shù)據(jù)存儲和消息隊列
MySQL 索引使用的注意事項
DDL、DML、DCL分別指什么
explain命令
left join,right join,inner join
數(shù)據(jù)庫事物ACID(原子性、一致性、隔離性、持久性)
事物的隔離級別(讀未提交、讀以提交、可重復(fù)讀、可序列化讀)
臟讀、幻讀、不可重復(fù)讀
數(shù)據(jù)庫的幾大范式
數(shù)據(jù)庫常見的命令
說說分庫與分表設(shè)計
分庫與分表帶來的分布式困境與應(yīng)對之策(如何解決分布式下的分庫分表,全局表?)
說說 SQL 優(yōu)化之道
MySQL遇到的死鎖問題、如何排查與解決
存儲引擎的 InnoDB與MyISAM區(qū)別,優(yōu)缺點,使用場景
索引類別(B+樹索引、全文索引、哈希索引)、索引的原理
什么是自適應(yīng)哈希索引(AHI)
為什么要用 B+tree作為MySQL索引的數(shù)據(jù)結(jié)構(gòu)
聚集索引與非聚集索引的區(qū)別
遇到過索引失效的情況沒,什么時候可能會出現(xiàn),如何解決
limit 20000 加載很慢怎么解決
如何選擇合適的分布式主鍵方案
選擇合適的數(shù)據(jù)存儲方案
常見的幾種分布式ID的設(shè)計方案
常見的數(shù)據(jù)庫優(yōu)化方案,在你的項目中數(shù)據(jù)庫如何進行優(yōu)化的
Redis 有哪些數(shù)據(jù)類型,可參考《Redis常見的5種不同的數(shù)據(jù)類型詳解》
Redis 內(nèi)部結(jié)構(gòu)
Redis 使用場景
Redis 持久化機制,可參考《使用快照和AOF將Redis數(shù)據(jù)持久化到硬盤中》
Redis 集群方案與實現(xiàn)
Redis 為什么是單線程的?
緩存雪崩、緩存穿透、緩存預(yù)熱、緩存更新、緩存降級
使用緩存的合理性問題
Redis常見的回收策略
消息隊列的使用場景
消息的重發(fā)補償解決思路
消息的冪等性解決思路
消息的堆積解決思路
自己如何實現(xiàn)消息隊列
如何保證消息的有序性
Servlet的生命周期
轉(zhuǎn)發(fā)與重定向的區(qū)別
BeanFactory 和 ApplicationContext 有什么區(qū)別
Spring Bean 的生命周期
Spring IOC 如何實現(xiàn)
Spring中Bean的作用域,默認的是哪一個
說說 Spring AOP、Spring AOP 實現(xiàn)原理
動態(tài)代理(CGLib 與 JDK)、優(yōu)缺點、性能對比、如何選擇
Spring 事務(wù)實現(xiàn)方式、事務(wù)的傳播機制、默認的事務(wù)類別
Spring 事務(wù)底層原理
Spring事務(wù)失效(事務(wù)嵌套),JDK動態(tài)代理給Spring事務(wù)埋下的坑,可參考《JDK動態(tài)代理給Spring事務(wù)埋下的坑!》
如何自定義注解實現(xiàn)功能
Spring MVC 運行流程
Spring MVC 啟動流程
Spring 的單例實現(xiàn)原理
Spring 框架中用到了哪些設(shè)計模式
Spring 其他產(chǎn)品(Srping Boot、Spring Cloud、Spring Secuirity、Spring Data、Spring AMQP 等)
有沒有用到Spring Boot,Spring Boot的認識、原理
MyBatis的原理
可參考《為什么會有Spring》
可參考《為什么會有Spring AOP》
為什么選擇 Netty
說說業(yè)務(wù)中,Netty 的使用場景
原生的 NIO 在 JDK 1.7 版本存在 epoll bug
什么是TCP 粘包/拆包
TCP粘包/拆包的解決辦法
Netty 線程模型
說說 Netty 的零拷貝
Netty 內(nèi)部執(zhí)行流程
Netty 重連實現(xiàn)
3.3、Tomcat
Tomcat的基礎(chǔ)架構(gòu)(Server、Service、Connector、Container)
Tomcat如何加載Servlet的
Pipeline-Valve機制
可參考:《四張圖帶你了解Tomcat系統(tǒng)架構(gòu)!》
請解釋什么是C10K問題或者知道什么是C10K問題嗎?
Nginx簡介,可參考《Nginx簡介》
正向代理和反向代理.
Nginx幾種常見的負載均衡策略
Nginx服務(wù)器上的Master和Worker進程分別是什么
使用“反向代理服務(wù)器”的優(yōu)點是什么?
談?wù)剺I(yè)務(wù)中使用分布式的場景
Session 分布式方案
Session 分布式處理
分布式鎖的應(yīng)用場景、分布式鎖的產(chǎn)生原因、基本概念
分布是鎖的常見解決方案
分布式事務(wù)的常見解決方案
集群與負載均衡的算法與實現(xiàn)
說說分庫與分表設(shè)計,可參考《數(shù)據(jù)庫分庫分表策略的具體實現(xiàn)方案》
分庫與分表帶來的分布式困境與應(yīng)對之策
4.3、Dubbo
什么是Dubbo,可參考《Dubbo入門》
什么是RPC、如何實現(xiàn)RPC、RPC 的實現(xiàn)原理,可參考《基于HTTP的RPC實現(xiàn)》
Dubbo中的SPI是什么概念
Dubbo的基本原理、執(zhí)行流程
五、微服務(wù)
5.1、微服務(wù)
前后端分離是如何做的?
微服務(wù)哪些框架
Spring Could的常見組件有哪些?可參考《Spring Cloud概述》
領(lǐng)域驅(qū)動有了解嗎?什么是領(lǐng)域驅(qū)動模型?充血模型、貧血模型
JWT有了解嗎,什么是JWT,可參考《前后端分離利器之JWT》
你怎么理解 RESTful
說說如何設(shè)計一個良好的 API
如何理解 RESTful API 的冪等性
如何保證接口的冪等性
說說 CAP 定理、BASE 理論
怎么考慮數(shù)據(jù)一致性問題
說說最終一致性的實現(xiàn)方案
微服務(wù)的優(yōu)缺點,可參考《微服務(wù)批判》
微服務(wù)與 SOA 的區(qū)別
如何拆分服務(wù)、水平分割、垂直分割
如何應(yīng)對微服務(wù)的鏈式調(diào)用異常
如何快速追蹤與定位問題
如何保證微服務(wù)的安全、認證
如何防范常見的Web攻擊、如何方式SQL注入
服務(wù)端通信安全攻防
HTTPS原理剖析、降級攻擊、HTTP與HTTPS的對比
性能指標有哪些
如何發(fā)現(xiàn)性能瓶頸
性能調(diào)優(yōu)的常見手段
說說你在項目中如何進行性能調(diào)優(yōu)
說說你在項目中使用過的UML圖
你如何考慮組件化、服務(wù)化、系統(tǒng)拆分
秒殺場景如何設(shè)計
可參考:《秒殺系統(tǒng)的技術(shù)挑戰(zhàn)、應(yīng)對策略以及架構(gòu)設(shè)計總結(jié)一二!》
說說你的開發(fā)流程、如何進行自動化部署的
你和團隊是如何溝通的
你如何進行代碼評審
說說你對技術(shù)與業(yè)務(wù)的理解
說說你在項目中遇到感覺最難Bug,是如何解決的
介紹一下工作中的一個你認為最有價值的項目,以及在這個過程中的角色、解決的問題、你覺得你們項目還有哪些不足的地方
說說你的優(yōu)缺點、亮點
說說你最近在看什么書、什么博客、在研究什么新技術(shù)、再看那些開源項目的源代碼
說說你覺得最有意義的技術(shù)書籍
工作之余做什么事情、平時是如何學(xué)習(xí)的,怎樣提升自己的能力
說說個人發(fā)展方向方面的思考
說說你認為的服務(wù)端開發(fā)工程師應(yīng)該具備哪些能力
說說你認為的架構(gòu)師是什么樣的,架構(gòu)師主要做什么
如何看待加班的問題
當然,一個完整的面試肯定不止上述的知識點,其他的諸如:Linux、數(shù)據(jù)結(jié)構(gòu)、算法、邏輯思維題、系統(tǒng)設(shè)計題、職業(yè)規(guī)劃等等都會有所涉及!總之,充分的準備是應(yīng)對一切面試的不二法寶!
聯(lián)系客服