阿里最新面試真題208解析:Mybatis、RabbitMQ、Kafka、Zookeeper

這份面試清單是從我 2017 年做了 TeamLeader 之後開始收集的,一方面是給公司招聘用,另一方面是想用它來挖掘在 Java 技術棧中,還有那些知識點是我不知道的,我想找到這些技術盲點,然後修復它,以此來提高自己的技術水平。雖然我是從 2009 年就開始參加編程工作了,但我依舊覺得自己現在要學的東西很多,並且學習這些知識,讓我很有成就感和滿足感,那所以何樂而不為呢?

說回面試的事,這份面試清單本來是隻有我們內部使用的,可到後來有很多朋友在微信上聯繫到我,讓我幫他們找一些面試方面的資料,而且這些關係也不太好拒絕,一呢,是因為這些找我的人要麼是我的朋友的弟弟妹妹,要麼是我的表弟表妹們;二呢,我也不想馬馬虎虎的對付,俗話說的好“受人之事忠人之命”,不能辜負這份信任。但最後就有了這麼一個想法,要不要把我整理的這 200 多道 Java 面試題分享出去,去幫助更多的人。

說實話剛開始的時候是比較猶豫的,首先這麼做會不會有點幫人“作弊”的嫌疑,最後我終於想通了,覺得這未必是一件壞事。

第一:有更多的人因此而學到了更多的知識,這不算是一件壞事,恰好相反。

第二:這只是一種經驗的高度提煉,讓那些有技術能力的人,學會如何表達自己所掌握的知識,這也是一件好事。

第三:如果只是死記硬背這些面試題,如果面試官能再深入問糾一些細節,也可識破之中的“玄機”。

第四:學習有很多種方式,但只有好學者才會臨池學書。如果是不想學的人,無論你提供什麼資料,他都會視而不見,我只是為好學者,提供一份自我實現的學習資料而已。

就像之前聽過的一個故事,為什麼在美國有些企業只要看你是哈佛的學歷就會直接錄取你呢?因為在美國上大學還是挺貴的,首先你能上的起哈佛說明你的家境還不錯;第二,你能進入哈佛,也說明你腦子不笨;再者就是,哈佛確實能給你提供不錯的教育環境。綜合以上特質,所以這些企業才敢直接聘請那些有哈佛學歷的人。

所以對應到我們這份面試題也是一樣,首先你如果能真的記住其中大部分的答案:第一,說明你的腦子不笨;第二,說明你有上進心,也願意學習;第三,記住了這份面試題之後,即使你的能力剛開始沒有那麼好,但有了理論支撐之後,再去工作實踐的時候,就有了理論指導,結果也不會太差。

所以如果您是面試官,恰好又看到這裡,如果條件允許的話,請多給這樣願意學又很聰明的年輕人一些機會,即使他們現在並沒有太多的實踐經驗。

面試題模塊介紹

說了這麼多,下面進入我們本文的主題,我們這份面試題,包含的內容了十九了模塊:Java 基礎、容器、多線程、反射、對象拷貝、Java Web 模塊、異常、網絡、設計模式、Spring/Spring MVC、Spring Boot/Spring Cloud、Hibernate、Mybatis、RabbitMQ、Kafka、Zookeeper、MySql、Redis、JVM 。如下圖所示:

可能對於初學者不需要後面的框架和 JVM 模塊的知識,讀者朋友們可根據自己的情況,選擇對應的模塊進行閱讀。

適宜閱讀人群

需要面試的初/中/高級 java 程序員想要查漏補缺的人想要不斷完善和擴充自己 java 技術棧的人java 面試官

具體面試題

下面一起來看 208 道面試題,具體的內容。

一、Java 基礎

JDK 和 JRE 有什麼區別?== 和 equals 的區別是什麼?兩個對象的 hashCode()相同,則 equals()也一定為 true,對嗎?final 在 java 中有什麼作用?java 中的 Math.round(-1.5) 等於多少?String 屬於基礎的數據類型嗎?java 中操作字符串都有哪些類?它們之間有什麼區別?String str="i"與 String str=new String(“i”)一樣嗎?如何將字符串反轉?String 類的常用方法都有那些?抽象類必須要有抽象方法嗎?普通類和抽象類有哪些區別?抽象類能使用 final 修飾嗎?接口和抽象類有什麼區別?java 中 IO 流分為幾種?BIO、NIO、AIO 有什麼區別?Files的常用方法都有哪些?

二、容器

java 容器都有哪些?Collection 和 Collections 有什麼區別?List、Set、Map 之間的區別是什麼?HashMap 和 Hashtable 有什麼區別?如何決定使用 HashMap 還是 TreeMap?說一下 HashMap 的實現原理?說一下 HashSet 的實現原理?ArrayList 和 LinkedList 的區別是什麼?如何實現數組和 List 之間的轉換?ArrayList 和 Vector 的區別是什麼?Array 和 ArrayList 有何區別?在 Queue 中 poll()和 remove()有什麼區別?哪些集合類是線程安全的?迭代器 Iterator 是什麼?Iterator 怎麼使用?有什麼特點?Iterator 和 ListIterator 有什麼區別?怎麼確保一個集合不能被修改?

三、多線程

並行和併發有什麼區別?線程和進程的區別?守護線程是什麼?創建線程有哪幾種方式?說一下 runnable 和 callable 有什麼區別?線程有哪些狀態?sleep() 和 wait() 有什麼區別?notify()和 notifyAll()有什麼區別?線程的 run()和 start()有什麼區別?創建線程池有哪幾種方式?線程池都有哪些狀態?線程池中 submit()和 execute()方法有什麼區別?在 java 程序中怎麼保證多線程的運行安全?多線程鎖的升級原理是什麼?什麼是死鎖?怎麼防止死鎖?ThreadLocal 是什麼?有哪些使用場景?說一下 synchronized 底層實現原理?synchronized 和 volatile 的區別是什麼?synchronized 和 Lock 有什麼區別?synchronized 和 ReentrantLock 區別是什麼?說一下 atomic 的原理?

四、反射

什麼是反射?什麼是 java 序列化?什麼情況下需要序列化?動態代理是什麼?有哪些應用?怎麼實現動態代理?

五、對象拷貝

為什麼要使用克隆?如何實現對象克隆?深拷貝和淺拷貝區別是什麼?

六、Java Web

jsp 和 servlet 有什麼區別?jsp 有哪些內置對象?作用分別是什麼?說一下 jsp 的 4 種作用域?session 和 cookie 有什麼區別?說一下 session 的工作原理?如果客戶端禁止 cookie 能實現 session 還能用嗎?spring mvc 和 struts 的區別是什麼?如何避免 sql 注入?什麼是 XSS 攻擊,如何避免?什麼是 CSRF 攻擊,如何避免?

七、異常

throw 和 throws 的區別?final、finally、finalize 有什麼區別?try-catch-finally 中哪個部分可以省略?try-catch-finally 中,如果 catch 中 return 了,finally 還會執行嗎?常見的異常類有哪些?

八、網絡

http 響應碼 301 和 302 代表的是什麼?有什麼區別?forward 和 redirect 的區別?簡述 tcp 和 udp的區別?tcp 為什麼要三次握手,兩次不行嗎?為什麼?說一下 tcp 粘包是怎麼產生的?OSI 的七層模型都有哪些?get 和 post 請求有哪些區別?如何實現跨域?說一下 JSONP 實現原理?

九、設計模式

說一下你熟悉的設計模式?簡單工廠和抽象工廠有什麼區別?

十、Spring/Spring MVC

為什麼要使用 spring?解釋一下什麼是 aop?解釋一下什麼是 ioc?spring 有哪些主要模塊?spring 常用的注入方式有哪些?spring 中的 bean 是線程安全的嗎?spring 支持幾種 bean 的作用域?spring 自動裝配 bean 有哪些方式?spring 事務實現方式有哪些?說一下 spring 的事務隔離?說一下 spring mvc 運行流程?spring mvc 有哪些組件?@RequestMapping 的作用是什麼?@Autowired 的作用是什麼?

十一、Spring Boot/Spring Cloud

什麼是 spring boot?為什麼要用 spring boot?spring boot 核心配置文件是什麼?spring boot 配置文件有哪幾種類型?它們有什麼區別?spring boot 有哪些方式可以實現熱部署?jpa 和 hibernate 有什麼區別?什麼是 spring cloud?spring cloud 斷路器的作用是什麼?spring cloud 的核心組件有哪些?

十二、Hibernate

為什麼要使用 hibernate?什麼是 ORM 框架?hibernate 中如何在控制檯查看打印的 sql 語句?hibernate 有幾種查詢方式?hibernate 實體類可以被定義為 final 嗎?在 hibernate 中使用 Integer 和 int 做映射有什麼區別?hibernate 是如何工作的?get()和 load()的區別?說一下 hibernate 的緩存機制?hibernate 對象有哪些狀態?在 hibernate 中 getCurrentSession 和 openSession 的區別是什麼?hibernate 實體類必須要有無參構造函數嗎?為什麼?

十三、Mybatis

mybatis 中 #{}和 ${}的區別是什麼?mybatis 有幾種分頁方式?RowBounds 是一次性查詢全部結果嗎?為什麼?mybatis 邏輯分頁和物理分頁的區別是什麼?mybatis 是否支持延遲加載?延遲加載的原理是什麼?說一下 mybatis 的一級緩存和二級緩存?mybatis 和 hibernate 的區別有哪些?mybatis 有哪些執行器(Executor)?mybatis 分頁插件的實現原理是什麼?mybatis 如何編寫一個自定義插件?

十四、RabbitMQ

rabbitmq 的使用場景有哪些?rabbitmq 有哪些重要的角色?rabbitmq 有哪些重要的組件?rabbitmq 中 vhost 的作用是什麼?rabbitmq 的消息是怎麼發送的?rabbitmq 怎麼保證消息的穩定性?rabbitmq 怎麼避免消息丟失?要保證消息持久化成功的條件有哪些?rabbitmq 持久化有什麼缺點?rabbitmq 有幾種廣播類型?rabbitmq 怎麼實現延遲消息隊列?rabbitmq 集群有什麼用?rabbitmq 節點的類型有哪些?rabbitmq 集群搭建需要注意哪些問題?rabbitmq 每個節點是其他節點的完整拷貝嗎?為什麼?rabbitmq 集群中唯一一個磁盤節點崩潰了會發生什麼情況?rabbitmq 對集群節點停止順序有要求嗎?

十五、Kafka

kafka 可以脫離 zookeeper 單獨使用嗎?為什麼?kafka 有幾種數據保留的策略?kafka 同時設置了 7 天和 10G 清除數據,到第五天的時候消息達到了 10G,這個時候 kafka 將如何處理?什麼情況會導致 kafka 運行變慢?使用 kafka 集群需要注意什麼?

十六、Zookeeper

zookeeper 是什麼?zookeeper 都有哪些功能?zookeeper 有幾種部署模式?zookeeper 怎麼保證主從節點的狀態同步?集群中為什麼要有主節點?集群中有 3 臺服務器,其中一個節點宕機,這個時候 zookeeper 還可以使用嗎?說一下 zookeeper 的通知機制?

十七、MySql

數據庫的三範式是什麼?一張自增表裡面總共有 7 條數據,刪除了最後 2 條數據,重啟 mysql 數據庫,又插入了一條數據,此時 id 是幾?如何獲取當前數據庫版本?說一下 ACID 是什麼?char 和 varchar 的區別是什麼?float 和 double 的區別是什麼?mysql 的內連接、左連接、右連接有什麼區別?mysql 索引是怎麼實現的?怎麼驗證 mysql 的索引是否滿足需求?說一下數據庫的事務隔離?說一下 mysql 常用的引擎?說一下 mysql 的行鎖和表鎖?說一下樂觀鎖和悲觀鎖?mysql 問題排查都有哪些手段?如何做 mysql 的性能優化?

十八、Redis

redis 是什麼?都有哪些使用場景?redis 有哪些功能?redis 和 memecache 有什麼區別?redis 為什麼是單線程的?什麼是緩存穿透?怎麼解決?redis 支持的數據類型有哪些?redis 支持的 java 客戶端都有哪些?jedis 和 redisson 有哪些區別?怎麼保證緩存和數據庫數據的一致性?redis 持久化有幾種方式?redis 怎麼實現分佈式鎖?redis 分佈式鎖有什麼缺陷?redis 如何做內存優化?redis 淘汰策略有哪些?redis 常見的性能問題有哪些?該如何解決?

十九、JVM

說一下 jvm 的主要組成部分?及其作用?說一下 jvm 運行時數據區?說一下堆棧的區別?隊列和棧是什麼?有什麼區別?什麼是雙親委派模型?說一下類加載的執行過程?怎麼判斷對象是否可以被回收?java 中都有哪些引用類型?說一下 jvm 有哪些垃圾回收算法?說一下 jvm 有哪些垃圾回收器?詳細介紹一下 CMS 垃圾回收器?新生代垃圾回收器和老生代垃圾回收器都有哪些?有什麼區別?簡述分代垃圾回收器是怎麼工作的?說一下 jvm 調優的工具?常用的 jvm 調優的參數都有哪些?

總結:

由於文章長度原因,答案和解析就沒有全部在這文中給大家展示出來了,我將所有的答案都整理在一個文檔裡面了,除了阿里的這208道題目之外,還總結了有秋招bat等大廠的面試真題,相信對你的知識能有一定的提升。

資料獲取方式:關注小編+轉發文章+私信:架構資料。