2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

前言:

前部分.是ThreadLocal補充模塊解析.

後部分.200+面試題內容.

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

1.ThreadLocal 是什麼?

ThreadLocal 是一個本地線程副本變量工具類。

主要用於將私有線程和該線程存放的副本對象做一個映射,各個線程之間的變量互不干擾,在高併發場景下,可以實現無狀態的調用,適用於各個線程不共享變量值的操作。

2.ThreadLocal 工作原理是什麼?

ThreadLocal 原理:每個線程的內部都維護了一個 ThreadLocalMap,它是一個 Map(key,value)數據格式,key 是一個弱引用,也就是 ThreadLocal 本身,而 value 存的是線程變量的值。

也就是說 ThreadLocal 本身並不存儲線程的變量值,它只是一個工具,用來維護線程內部的 Map,幫助存和取變量。

數據結構,如下圖所示:

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

3.ThreadLocal 如何解決 Hash 衝突?

與 HashMap 不同,ThreadLocalMap 結構非常簡單,沒有 next 引用.

也就是說 ThreadLocalMap 中解決 Hash 衝突的方式並非鏈表的方式,而是採用線性探測的方式.

所謂線性探測,就是根據初始 key 的 hashcode 值確定元素在 table 數組中的位置,如果發現這個位置上已經被其他的 key 值佔用,則利用固定的算法尋找一定步長的下個位置,依次判斷,直至找到能夠存放的位置。

源代碼實現如下:

<code>/
* Increment i modulo len.
*/
private static int nextIndex(int i, int len) {
return ((i + 1 < len) ? i + 1 : 0);
}

/
* Decrement i modulo len.
*/
private static int prevIndex(int i, int len) {
return ((i - 1 >= 0) ? i - 1 : len - 1);
}/<code>

4.ThreadLocal 的內存洩露是怎麼回事?

ThreadLocal 在 ThreadLocalMap 中是以一個弱引用身份被 Entry 中的 Key 引用的,因此如果 ThreadLocal 沒有外部強引用來引用它,那麼 ThreadLocal 會在下次 JVM 垃圾收集時被回收。

這個時候 Entry 中的 key 已經被回收,但是 value 又是一強引用不會被垃圾收集器回收,這樣 ThreadLocal 的線程如果一直持續運行,value 就一直得不到回收,這樣就會發生內存洩露。

5.為什麼 ThreadLocalMap 的 key 是弱引用?

我們知道 ThreadLocalMap 中的 key 是弱引用,而 value 是強引用才會導致內存洩露的問題,至於為什麼要這樣設計,這樣分為兩種情況來討論:

  • key 使用強引用:這樣會導致一個問題,引用的 ThreadLocal 的對象被回收了,但是 ThreadLocalMap 還持有 ThreadLocal 的強引用,如果沒有手動刪除,ThreadLocal 不會被回收,則會導致內存洩漏。
  • key 使用弱引用:這樣的話,引用的 ThreadLocal 的對象被回收了,由於 ThreadLocalMap 持有 ThreadLocal 的弱引用,即使沒有手動刪除,ThreadLocal 也會被回收。value 在下一次 ThreadLocalMap 調用 set、get、remove 的時候會被清除。

比較以上兩種情況,我們可以發現:由於 ThreadLocalMap 的生命週期跟 Thread 一樣長,如果都沒有手動刪除對應 key,都會導致內存洩漏.

但是使用弱引用可以多一層保障,弱引用 ThreadLocal 不會內存洩漏,對應的 value 在下一次 ThreadLocalMap 調用 set、get、remove 的時候被清除,算是最優的解決方案。

6.ThreadLocal 的應用場景有哪些?

ThreadLocal 適用於獨立變量副本的情況,比如 Hibernate 的 session 獲取場景。

示例代碼:

<code>private static final ThreadLocal<session> threadLocal = new ThreadLocal<session>();

public static Session getCurrentSession(){
Session session = threadLocal.get();
try {
if(session ==null&&!session.isOpen()){
//...
}
threadLocal.set(session);
} catch (Exception e) {
// TODO: handle exception
}
return session;
}/<session>/<session>/<code>

剩餘全部模塊知識點,包含了十九個模塊內容了:Java 基礎、容器、多線程、反射、對象拷貝、Java Web 模塊、異常、網絡、設計模式、Spring/Spring MVC、Spring Boot/Spring Cloud、Hibernate、Mybatis、RabbitMQ、Kafka、Zookeeper、MySql、Redis、JVM 。

如下圖所示:

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

讀者朋友們可根據自己的情況,選擇對應的模塊進行閱讀。

適宜閱讀人群

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

具體面試題

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

下面一起來看 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 調優的參數都有哪些?
下面展示了部分資料,也希望也能幫助到大家,對編程感興趣想進階的朋友,如果能幫到你請點贊、點贊、點贊:

整理的 pdf 文檔:

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

源碼分析專題部分課程:

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

2020最新Java 200+面試題(補充ThreadLocal 模塊解析)

獲取方式

點贊,收藏並轉發文章後點擊小編頭像或暱稱,關注後私信回覆:【11】 即可

舉手之勞,非常感謝!!!


分享到:


相關文章: