44. 創(chuàng)建線程池有哪幾種方式? 45. 線程池都有哪些狀態(tài)? 46. 線程池中 submit() 和 execute() 方法有什么區(qū)別? 47. 在 Java 程序中怎么保證多線程的運行安全? 48. 多線程中 synchronized 鎖升級的原理是什么? 49. 什么是死鎖? 50. 怎么防止死鎖? 51. ThreadLocal 是什么?有哪些使用場景? 52. 說一下 synchronized 底層實現(xiàn)原理? 53. synchronized 和 volatile 的區(qū)別是什么? 54. synchronized 和 Lock 有什么區(qū)別? 55. synchronized 和 ReentrantLock 區(qū)別是什么? 56. 說一下 atomic 的原理? 反射 == 57. 什么是反射? 58. 什么是 Java 序列化?什么情況下需要序列化? 59. 動態(tài)代理是什么?有哪些應用? 60. 怎么實現(xiàn)動態(tài)代理? 對象拷貝 ==== 61. 為什么要使用克??? 62. 如何實現(xiàn)對象克??? 63. 深拷貝和淺拷貝區(qū)別是什么? Java Web ======== 64. JSP 和 servlet 有什么區(qū)別? 65. JSP 有哪些內(nèi)置對象?作用分別是什么? 66. 說一下 JSP 的 4 種作用域? 67. session 和 cookie 有什么區(qū)別? 68. 說一下 session 的工作原理? 69. 如果客戶端禁止 cookie 能實現(xiàn) session 還能用嗎? 70. spring mvc 和 struts 的區(qū)別是什么? 71. 如何避免 SQL 注入? 72. 什么是 XSS 攻擊,如何避免? 73. 什么是 CSRF 攻擊,如何避免? 異常 == 74. throw 和 throws 的區(qū)別? 75. final、finally、finalize 有什么區(qū)別? 76. try-catch-finally 中哪個部分可以省略? 77. try-catch-finally 中,如果 catch 中 return 了,finally 還會執(zhí)行嗎? 78. 常見的異常類有哪些? 網(wǎng)絡 == 79. http 響應碼 301 和 302 代表的是什么?有什么區(qū)別? 80. forward 和 redirect 的區(qū)別? 81. 簡述 tcp 和 udp的區(qū)別? 82. tcp 為什么要三次握手,兩次不行嗎?為什么? 83. 說一下 tcp 粘包是怎么產(chǎn)生的? 84. OSI 的七層模型都有哪些? 85. get 和 post 請求有哪些區(qū)別? 86. 如何實現(xiàn)跨域? 87. 說一下 JSONP 實現(xiàn)原理? 設計模式 ==== 88. 說一下你熟悉的設計模式? 89. 簡單工廠和抽象工廠有什么區(qū)別? Spring/Spring MVC ================= 90. 為什么要使用 spring? 91. 解釋一下什么是 aop? 92. 解釋一下什么是 ioc? 93. spring 有哪些主要模塊? 94. spring 常用的注入方式有哪些? 95. spring 中的 bean 是線程安全的嗎? 96. spring 支持幾種 bean 的作用域? 97. spring 自動裝配 bean 有哪些方式? 98. spring 事務實現(xiàn)方式有哪些? 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 配置文件有哪幾種類型?它們有什么區(qū)別? 108. spring boot 有哪些方式可以實現(xiàn)熱部署? 109. jpa 和 hibernate 有什么區(qū)別? 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 做映射有什么區(qū)別? 119. hibernate 是如何工作的? 120. get()和 load()的區(qū)別? 121. 說一下 hibernate 的緩存機制? 122. hibernate 對象有哪些狀態(tài)? 123. 在 hibernate 中 getCurrentSession 和 openSession 的區(qū)別是什么? 124. hibernate 實體類必須要有無參構造函數(shù)嗎?為什么? MyBatis ======= 125. MyBatis 中 #{}和 ${}的區(qū)別是什么? 126. MyBatis 有幾種分頁方式? 127. RowBounds 是一次性查詢?nèi)拷Y果嗎?為什么? 128. MyBatis 邏輯分頁和物理分頁的區(qū)別是什么? 129. MyBatis 是否支持延遲加載?延遲加載的原理是什么? 130. 說一下 MyBatis 的一級緩存和二級緩存? 131. MyBatis 和 hibernate 的區(qū)別有哪些? 132. MyBatis 有哪些執(zhí)行器(Executor)? 133. MyBatis 分頁插件的實現(xiàn)原理是什么? 134. MyBatis 如何編寫一個自定義插件? RabbitMQ ======== 135. RabbitMQ 的使用場景有哪些? 136. RabbitMQ 有哪些重要的角色? 137. RabbitMQ 有哪些重要的組件? 138. RabbitMQ 中 vhost 的作用是什么? 139. RabbitMQ 的消息是怎么發(fā)送的? 140. RabbitMQ 怎么保證消息的穩(wěn)定性? 141. RabbitMQ 怎么避免消息丟失? 142. 要保證消息持久化成功的條件有哪些? 143. RabbitMQ 持久化有什么缺點? 144. RabbitMQ 有幾種廣播類型? 145. RabbitMQ 怎么實現(xiàn)延遲消息隊列? 146. RabbitMQ 集群有什么用? 147. RabbitMQ 節(jié)點的類型有哪些? 148. RabbitMQ 集群搭建需要注意哪些問題? 149. RabbitMQ 每個節(jié)點是其他節(jié)點的完整拷貝嗎?為什么? 150. RabbitMQ 集群中唯一一個磁盤節(jié)點崩潰了會發(fā)生什么情況? 151. RabbitMQ 對集群節(jié)點停止順序有要求嗎? Kafka ===== 152. kafka 可以脫離 zookeeper 單獨使用嗎?為什么? 153. kafka 有幾種數(shù)據(jù)保留的策略? 154. kafka 同時設置了 7 天和 10G 清除數(shù)據(jù),到第五天的時候消息達到了 10G,這個時候 kafka 將如何處理? 155. 什么情況會導致 kafka 運行變慢? 156. 使用 kafka 集群需要注意什么? Zookeeper ========= 157. zookeeper 是什么? 158. zookeeper 都有哪些功能? 159. zookeeper 有幾種部署模式? 160. zookeeper 怎么保證主從節(jié)點的狀態(tài)同步? 161. 集群中為什么要有主節(jié)點? 162. 集群中有 3 臺服務器,其中一個節(jié)點宕機,這個時候 zookeeper 還可以使用嗎? 163. 說一下 zookeeper 的通知機制? MySQL ========= 164. 數(shù)據(jù)庫的三范式是什么? 165. 一張自增表里面總共有 7 條數(shù)據(jù),刪除了最后 2 條數(shù)據(jù),重啟 MySQL 數(shù)據(jù)庫,又插入了一條數(shù)據(jù),此時 id 是幾? 166. 如何獲取當前數(shù)據(jù)庫版本? 167. 說一下 ACID 是什么? 168. char 和 varchar 的區(qū)別是什么? 169. float 和 double 的區(qū)別是什么? 170. MySQL 的內(nèi)連接、左連接、右連接有什么區(qū)別? 171. MySQL 索引是怎么實現(xiàn)的? 172. 怎么驗證 MySQL 的索引是否滿足需求? 173. 說一下數(shù)據(jù)庫的事務隔離? 174. 說一下 MySQL 常用的引擎? 175. 說一下 MySQL 的行鎖和表鎖? 最后,附一張自己面試前準備的腦圖: 面試前一定少不了刷題,為了方便大家復習,我分享一波個人整理的面試大全寶典
Step3:刷題 既然是要面試,那么就少不了刷題,實際上春節(jié)回家后,哪兒也去不了,我自己是刷了不少面試題的,所以在面試過程中才能夠做到心中有數(shù),基本上會清楚面試過程中會問到哪些知識點,高頻題又有哪些,所以刷題是面試前期準備過程中非常重要的一點。 以下是我私藏的面試題庫: 很多人感嘆“學習無用”,實際上之所以產(chǎn)生無用論,是因為自己想要的與自己所學的匹配不上,這也就意味著自己學得遠遠不夠。無論是學習還是工作,都應該有主動性,所以如果擁有大廠夢,那么就要自己努力去實現(xiàn)它。 CodeChina開源項目:【一線大廠Java面試題解析+核心總結學習筆記+最新講解視頻】 最后祝愿各位身體健康,順利拿到心儀的offer! |
|
來自: 昵稱75895347 > 《待分類》