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

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

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

說回面試的事,這份面試清單本來是隻有我們內部使用的,可到後來有很多朋友在微信上聯繫到我,讓我幫他們找一些面試方面的資料,而且這些關係也不太好拒絕,一呢,是因為這些找我的人要麼是我的朋友的弟弟妹妹,要麼是我的表弟表妹們;二呢,我也不想馬馬虎虎的對付,俗話說的好“受人之事忠人之命”,不能辜負這份信任。但最後就有了這麼一個想法,要不要把我整理的這 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等大廠的面試真題,相信對你的知識能有一定的提升。

資料獲取方式:關注小編+轉發文章+私信:架構資料。
阿里最新面試真題208解析:Mybatis、RabbitMQ、Kafka、Zookeeper


分享到:


相關文章: