200+面試題記錄
可能對於初學者不需要後面的框架和 JVM 模塊的知識,讀者朋友們可根據自己的情況,選擇對應的模塊進行閱讀。
適宜閱讀人群
需要面試的初/中/高級 java 程序員
想要查漏補缺的人
想要不斷完善和擴充自己 java 技術棧的人
java 面試官
具體面試題
下面一起來看 208 道面試題,具體的內容。
一、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 調優的參數都有哪些?
200+面試題記錄