02.26 不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強

前言

春招,秋招,社招,我們Java程序員的面試之路,是挺難的,過了HR,還得被技術面,小刀在去各個廠面試的時候,經常是通宵睡不著覺,頭髮都脫了一大把,還好最終僥倖能夠入職一個獨角獸公司,安穩從事喜歡的工作至今....

近期也算是抽取出大部分休息的時間,為大家準備了一份通往大廠面試的小捷徑,準備了一整套Java複習面試的刷題以及答案,我知道很多同學不知道怎麼複習,不知道學習過程中哪些才是重點,其實,你們經歷過的事情,小馬也經歷過,正應為經歷過,所以不願意看到還有萬千學子為此傷神,也許這篇文章幫不到萬千學子,但是能夠在頭條這個平臺上幫助到正在看這篇文章的那個迷茫的你! 小馬也就滿足了!

具體面試題如下

一、Java 基礎

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

二、容器

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

三、多線程

  • 35. 並行和併發有什麼區別?
  • 36. 線程和進程的區別?
  • 37. 守護線程是什麼?
  • 38. 創建線程有哪幾種方式?
  • 39. 說一下 runnable 和 callable 有什麼區別?
  • 40. 線程有哪些狀態?
  • 41. sleep() 和 wait() 有什麼區別?
  • 42. notify()和 notifyAll()有什麼區別?
  • 43. 線程的 run()和 start()有什麼區別?
  • 44.創建線程池有哪幾種方式?
  • 45.線程池都有哪些狀態?
  • 46. 線程池中 submit()和 execute()方法有什麼區別?
  • 47. 在 java 程序中怎麼保證多線程的運行安全?
  • 48. 多線程鎖的升級原理是什麼?
  • 49. 什麼是死鎖?
  • 50. 怎麼防止死鎖?
  • 51. ThreadLocal 是什麼?有哪些使用場景?
  • 52. 說一下 synchronized 底層實現原理?
  • 53. synchronized 和 volatile 的區別是什麼?
  • 54. synchronized 和 Lock 有什麼區別?
  • 55. synchronized 和 ReentrantLock 區別是什麼?
  • 56. 說一下 atomic 的原理?

四、反射

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

五、對象拷貝

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

六、Java Web

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

七、異常

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

八、網絡

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

九、設計模式

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

十、Spring/Spring MVC

  • 90. 為什麼要使用 spring?
  • 91. 解釋一下什麼是 aop?
  • 92. 解釋一下什麼是 ioc?
  • 93. spring 有哪些主要模塊?
  • 94. spring 常用的注入方式有哪些?
  • 95. spring 中的 bean 是線程安全的嗎?
  • 96. spring 支持幾種 bean 的作用域?
  • 97. spring 自動裝配 bean 有哪些方式?
  • 98. spring 事務實現方式有哪些?
  • 99. 說一下 spring 的事務隔離?
  • 100. 說一下 spring mvc 運行流程?
  • 101. spring mvc 有哪些組件?
  • 102. @RequestMapping 的作用是什麼?
  • 103. @Autowired 的作用是什麼?

十一、Spring Boot/Spring Cloud

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

十二、Hibernate

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

十三、Mybatis

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

十四、RabbitMQ

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

十五、Kafka

  • 152. kafka 可以脫離 zookeeper 單獨使用嗎?為什麼?
  • 153. kafka 有幾種數據保留的策略?
  • 154. kafka 同時設置了 7 天和 10G 清除數據,到第五天的時候消息達到了 10G,這個時候 kafka 將如何處理?
  • 155. 什麼情況會導致 kafka 運行變慢?
  • 156. 使用 kafka 集群需要注意什麼?
  • 十六、Zookeeper
  • 157. zookeeper 是什麼?
  • 158. zookeeper 都有哪些功能?
  • 159. zookeeper 有幾種部署模式?
  • 160. zookeeper 怎麼保證主從節點的狀態同步?
  • 161. 集群中為什麼要有主節點?
  • 162. 集群中有 3 臺服務器,其中一個節點宕機,這個時候 zookeeper 還可以使用嗎?
  • 163. 說一下 zookeeper 的通知機制?

十七、MySql

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

十八、Redis

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

十九、JVM

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

我們與其羨慕他人的成功,不如從此刻開始,積累足夠多的知識和麵試經驗,為將來進入更好的公司做充分的準備!機會永遠屬於有準備的人~希望大家學完之後,都能拿到自己心儀的 Offer!!

小馬哥也花費好幾個月收集整理了各大廠常見面試題N道,你想要的這裡都有內容涵蓋:

Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、Redis、MySQL、Spring、Spring Boot、Spring Cloud、RabbitMQ、Kafka、Linux等技術棧,

目的只有一個,希望大家都能找到適合自己的公司,開開心心的擼代碼。也希望能夠結交到更多的朋友!

目錄:

由於題量較多,篇幅的限制,文章中的面試題分享沒有全部附上詳細的解析,但是整理成了一份詳細的PDF文檔可分享給大家,轉發+關注 後臺私信【面試資料】 即可免費領取文章提及資料!

不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


看面試題可以是為了面試,也可以是對自己學到的東西的一種查漏補缺,更加深刻的去了解一些核心知識點


不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


MyBatis 面試題

  • 1、什麼是 Mybatis?
  • 2、Mybaits 的優點:
  • 3、MyBatis 框架的缺點:
  • 4、MyBatis 框架適用場合:
  • 5、MyBatis 與 Hibernate 有哪些不同?
  • 6、#{}和${}的區別是什麼?
  • 7、當實體類中的屬性名和表中的字段名不一樣 ,怎麼辦 ?
  • 8、 模糊查詢 like 語句該怎麼寫?

第 1 種:在 Java 代碼中添加 sql 通配符。

<code>string wildcardname = “%smi%”;list<name> names = mapper.selectlike(wildcardname);<select>select * from foo where bar like #{value}/<select>/<name>/<code>

轉發+關注 後臺私信【面試資料】 即可免費領取文中提及資料!


不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


ZooKeeper 面試題

ZooKeeper 是一個開源的分佈式協調服務,由雅虎創建,是 Google Chubby 的開源實現。分佈式應用程序可以基於 ZooKeeper 實現諸如數據發佈/訂閱、負載均衡、命名服務、分佈式協調/通知、集群管理、Master 選舉、配置維護,名字服務、分佈式同步、分佈式鎖和分佈式隊列等功能。

  • zookeeper 負載均衡和 nginx 負載均衡區別
  • Zookeeper Watcher 機制--數據變更通知
  • 客戶端註冊 Watcher 實現
  • zookeeper 是如何保證事務的順序一致性的?
  • Zookeeper 對節點的 watch監聽通知是永久的嗎?為什麼不是永久的?
  • zk 節點宕機如何處理?

Zookeeper 本身也是集群,推薦配置不少於 3 個服務器。Zookeeper 自身也要保證當一個節點宕機時,其他節點會繼續提供服務。如果是一個 Follower 宕機,還有 2 臺服務器提供訪問,因為Zookeeper 上的數據是有多個副本的,數據並不會丟失;如果是一個 Leader 宕機,Zookeeper 會選舉出新的 Leader。ZK 集群的機制是隻要超過半數的節點正常,集群就能正常提供服務。只有在 ZK節點掛得太多,只剩一半或不到一半節點能工作,集群才失效。所以3 個節點的 cluster 可以掛掉 1 個節點(leader 可以得到 2 票>1.5)2 個節點的 cluster 就不能掛掉任何 1 個節點了(leader 可以得到 1 票<=1)

..........


不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


Dubbo 面試題

Spring Eureka 從開源轉變為閉源,Consul 正在崛起,而 Dubbo 又開始重新更新。目前市場上仍有不少公司使用dubbo我們也需要繼續學習。

  • 為什麼要用 Dubbo?
  • 默認使用的是什麼通信框架,還有別的選擇嗎?
  • 服務調用是阻塞的嗎?
  • 一般使用什麼註冊中心?還有別的選擇嗎?
  • 默認使用什麼序列化框架,你知道的還有哪些?
  • Dubbo 的整體架構設計有哪些分層?


不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


...............


不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


Elasticsearch 面試題

  • elasticsearch 瞭解多少,說說你們公司 es 的集群架構,索引數據大小,分片有多少,以及一些調優手段 。
  • elasticsearch 索引數據多了怎麼辦,如何調優,部署
  • elasticsearch 是如何實現 master 選舉的
  • Elasticsearch 在部署時,對 Linux 的設置有哪些優化方法
  • 詳細描述一下 Elasticsearch 更新和刪除文檔的過程。
  • Elasticsearch 在部署時,對 Linux 的設置有哪些優化方法?

...........


不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


Redis面試題

隨著應用研發技術的不斷成熟,Redis 緩存技術已經成為後臺研發同學必備的能力之一。在很多公司面試的過程中,都必不可少地考察 Redis 知識點的掌握。

  • 使用 Redis 有哪些好處?
  • Redis 是單進程單線程的?
  • Redis 的持久化機制是什麼?各自的優缺點?
  • Redis 常見異常問題和解決方案(雪崩,穿透...)
  • redis 過期鍵的刪除策略?
  • 為什麼 redis 需要把所有數據放到內存中?
  • Redis 集群的主從複製模型是怎樣的?
  • Redis key 的過期時間和永久有效分別怎麼設置?

轉發+關注 後臺私信【面試資料】 即可免費領取文中提及資料!

不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強

MySQL 面試題

如今互聯網行業用的最多就是 MySQL,然而對於高級 Web 面試者,尤其對於尋找 30k 下工作的求職者,很多 MySQL 相關知識點基本都會涉及,如果面試中,你的相關知識答的模糊和不切要點,基本大多稍好公司的面試官,基本也不會對你有興趣,畢竟稍微量大的項目,最終都會讓你去深入數據庫,而且最終的大多瓶頸首先也會出現在數據庫。

  • MySQL 相關存儲引擎。
  • MySQL 索引實現原理。
  • MySQL 數據庫鎖。
  • MySQL 的 SQL 調優。
  • MySQL 分表分庫全局 ID。

...............


不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


Java 併發編程

  • 在 java 中守護線程和本地線程區別?
  • 什麼是多線程中的上下文切換?
  • Java 中用到的線程調度算法是什麼?
  • 什麼是線程組,為什麼在 Java 中不推薦使用?
  • 在 Java 中 Executor 和 Executors 的區別?
  • 併發編程三要素?
  • 什麼是線程池?有哪幾種創建方式?

.........

不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


Spring 面試題

  • 1. 談談對 Spring IoC 的理解?
  • 2. 談談對 Spring DI 的理解?
  • 3. BeanFactory 接口和 ApplicationContext 接口不同點是什麼?
  • 4. 請介紹你熟悉的 Spring 核心類,並說明有什麼作用?
  • 5. 介紹一下 Spring 的事務的瞭解?
  • 6. 介紹一下 Spring 的事務實現方式?
  • 7.什麼是 Spring 的依賴注入?

..........

不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


Kafka面試題

  • Kafka 與傳統 MQ 消息系統之間有三個關鍵區別
  • 講一講 kafka 的 ack 的三種機制
  • 消費者故障,出現活鎖問題如何解決?
  • kafka 分佈式(不是單機)的情況下,如何保證消息的順序消費
  • kafka 如何不消費重複數據?比如扣款,我們不能重複的扣。

....


不願看到你迷茫,Java程序員面試刷題指南,全網最全,最強


讀者福利

由於題量較多,篇幅的限制,文章中的面試題分享沒有全部附上詳細的解析,希望各位同仁理解但是整理成了一份詳細的PDF文檔可分享給大家

真誠分享,如果文章能夠幫到您,那麼我寫這篇文章也就滿足了,獲取方式,轉發+關注 後臺私信【面試資料】 即可免費領取文中提及資料!


分享到:


相關文章: