Java集合22題
-
ArrayList 和 Vector 的區別。
-
說說 ArrayList,Vector, LinkedList 的存儲性能和特性。
-
快速失敗 (fail-fast) 和安全失敗 (fail-safe) 的區別是什麼?
-
hashmap 的數據結構。
-
HashMap 的工作原理是什麼?
-
Hashmap 什麼時候進行擴容呢?
-
List、Map、Set 三個接口,存取元素時,各有什麼特點?
-
Set 裏的元素是不能重複的,那麼用什麼方法來區分重複與否呢? 是用 == 還是 equals()? 它們有何區別?
-
兩個對象值相同 (x.equals(y) == true),但卻可有不同的 hash code,這句話對不對?
-
heap 和 stack 有什麼區別。
-
Java 集合類框架的基本接口有哪些?
-
HashSet 和 TreeSet 有什麼區別?
-
HashSet 的底層實現是什麼?
-
LinkedHashMap 的實現原理?
-
爲什麼集合類沒有實現 Cloneable 和 Serializable 接口?
-
什麼是迭代器 (Iterator)?
-
Iterator 和 ListIterator 的區別是什麼?
-
數組 (Array) 和列表 (ArrayList) 有什麼區別?什麼時候應該使用 Array 而不是 ArrayList?
-
Java 集合類框架的最佳實踐有哪些?
-
Set 裏的元素是不能重複的,那麼用什麼方法來區分重複與否呢?是用 == 還是 equals()?它們有何區別?
-
Comparable 和 Comparator 接口是幹什麼的?列出它們的區別
-
Collection 和 Collections 的區別。
JVM與調優21題
-
Java 類加載過程?
-
描述一下 JVM 加載 Class 文件的原理機制?
-
Java 內存分配。
-
GC 是什麼? 爲什麼要有 GC?
-
簡述 Java 垃圾回收機制
-
如何判斷一個對象是否存活?(或者 GC 對象的判定方法)
-
垃圾回收的優點和原理。並考慮 2 種回收機制
-
垃圾回收器的基本原理是什麼?垃圾回收器可以馬上回收內存嗎?有什麼辦法主動通知虛擬機進行垃圾回收?
-
Java 中會存在內存泄漏嗎,請簡單描述
-
深拷貝和淺拷貝。
-
System.gc() 和 Runtime.gc() 會做什麼事情?
-
finalize() 方法什麼時候被調用?析構函數 (finalization) 的目的是什麼?
-
如果對象的引用被置爲 null,垃圾收集器是否會立即釋放對象佔用的內存?
-
什麼是分佈式垃圾回收(DGC)?它是如何工作的?
-
串行(serial)收集器和吞吐量(throughput)收集器的區別是什麼?
-
在 Java 中,對象什麼時候可以被垃圾回收?
-
簡述 Java 內存分配與回收策率以及 Minor GC 和 Major GC。
-
JVM 的永久代中會發生垃圾回收麼?
-
Java 中垃圾收集的方法有哪些?
-
什麼是類加載器,類加載器有哪些?
-
類加載器雙親委派模型機制?
併發編程28題
-
Synchronized 用過嗎,其原理是什麼?
-
你剛纔提到獲取對象的鎖,這個“鎖”到底是什麼?如何確定對象的鎖?
-
什麼是可重入性,爲什麼說 Synchronized 是可重入鎖?
-
JVM 對 Java 的原生鎖做了哪些優化?48
-
爲什麼說 Synchronized 是非公平鎖?49
-
什麼是鎖消除和鎖粗化?49
-
爲什麼說 Synchronized 是一個悲觀鎖?樂觀鎖的實現原理又是什麼?什麼是 CAS,它有什麼特性?
-
樂觀鎖一定就是好的嗎?
-
跟 Synchronized 相比,可重入鎖 ReentrantLock 其實現原理有什麼不同?
-
那麼請談談 AQS 框架是怎麼回事兒?
-
請儘可能詳盡地對比下 Synchronized 和 ReentrantLock 的異同。
-
ReentrantLock 是如何實現可重入性的?
-
除了 ReetrantLock,你還接觸過 JUC 中的哪些併發工具?
-
請談談 ReadWriteLock 和 StampedLock。
-
如何讓 Java 的線程彼此同步?你瞭解過哪些同步器?請分別介紹下。
-
CyclicBarrier 和 CountDownLatch 看起來很相似,請對比下呢?
-
Java 線程池相關問題
-
Java 中的線程池是如何實現的?
-
創建線程池的幾個核心構造參數?
-
線程池中的線程是怎麼創建的?是一開始就隨着線程池的啓動創建好的嗎?
-
既然提到可以通過配置不同參數創建出不同的線程池,那麼 Java 中默認實現好的線程池又有哪些呢?請比較它們的異同
-
如何在 Java 線程池中提交線程?
-
什麼是 Java 的內存模型,Java 中各個線程是怎麼彼此看到對方的變量的?
-
請談談 volatile 有什麼特點,爲什麼它能保證變量對所有線程的可見性?
-
既然 volatile 能夠保證線程間的變量可見性,是不是就意味着基於 volatile 變量的運算就是併發安全的?
-
請對比下 volatile 對比 Synchronized 的異同。
-
請談談 ThreadLocal 是怎麼解決併發安全的?
-
很多人都說要慎用 ThreadLocal,談談你的理解,使用 ThreadLocal 需要注意些什麼?
spring 25題
-
1、什麼是 Spring 框架?Spring 框架有哪些主要模塊?
-
2、使用 Spring 框架能帶來哪些好處?
-
3、什麼是控制反轉(IOC)?什麼是依賴注入?
-
4、請解釋下 Spring 框架中的 IoC?
-
5、BeanFactory 和 ApplicationContext 有什麼區別?
-
6、Spring 有幾種配置方式?
-
7、如何用基於 XML 配置的方式配置 Spring?
-
8、如何用基於 Java 配置的方式配置 Spring?
-
9、怎樣用註解的方式配置 Spring?
-
10、請解釋 Spring Bean 的生命週期?
-
11、Spring Bean 的作用域之間有什麼區別?
-
12、什麼是 Spring inner beans?
-
13、Spring 框架中的單例 Beans 是線程安全的麼?
-
14、請舉例說明如何在 Spring 中注入一個 Java Collection?
-
15、如何向 Spring Bean 中注入一個 Java.util.Properties?
-
16、請解釋 Spring Bean 的自動裝配?
-
17、請解釋自動裝配模式的區別?
-
18、如何開啓基於註解的自動裝配?
-
19、請舉例解釋@Required 註解?
-
20、請舉例解釋@Autowired 註解?
-
21、請舉例說明@Qualifier 註解?
-
22、構造方法注入和設值注入有什麼區別?
-
23、Spring 框架中有哪些不同類型的事件?
-
24、FileSystemResource 和 ClassPathResource 有何區別?
-
25、Spring 框架中都用到了哪些設計模式?
設計模式 10題
-
1.請列舉出在 JDK 中幾個常用的設計模式?
-
2.什麼是設計模式?你是否在你的代碼裏面使用過任何設計模式?
-
3.Java 中什麼叫單例設計模式?請用 Java 寫出線程安全的單例模式
-
4.在 Java 中,什麼叫觀察者設計模式(observer design pattern)?
-
5.使用工廠模式最主要的好處是什麼?在哪裏使用?
-
6.舉一個用 Java 實現的裝飾模式(decorator design pattern)?它是作用於對象層次還是類
-
層次?
-
7.在 Java 中,爲什麼不允許從靜態方法中訪問非靜態變量?
-
8.設計一個 ATM 機,請說出你的設計思路?
-
9.在 Java 中,什麼時候用重載,什麼時候用重寫?
-
10.舉例說明什麼情況下會更傾向於使用抽象類而不是接口
springboot 22題
-
什麼是 Spring Boot?
-
Spring Boot 有哪些優點?
-
什麼是 JavaConfig?
-
如何重新加載 Spring Boot 上的更改,而無需重新啓動服務器?
-
Spring Boot 中的監視器是什麼?
-
如何在 Spring Boot 中禁用 Actuator 端點安全性?
-
如何在自定義端口上運行 Spring Boot 應用程序?
-
什麼是 YAML?
-
如何實現 Spring Boot 應用程序的安全性?
-
如何集成 Spring Boot 和 ActiveMQ?
-
如何使用 Spring Boot 實現分頁和排序?
-
什麼是 Swagger?你用 Spring Boot 實現了它嗎?
-
什麼是 Spring Profiles?
-
什麼是 Spring Batch?
-
什麼是 FreeMarker 模板?
-
如何使用 Spring Boot 實現異常處理?
-
您使用了哪些 starter maven 依賴項?
-
什麼是 CSRF 攻擊?
-
什麼是 WebSockets?
-
什麼是 AOP?
-
什麼是 Apache Kafka?
-
我們如何監視所有 Spring Boot 微服務?
Netty10題
-
BIO、NIO和AIO的區別?
-
NIO的組成?
-
Netty的特點?
-
Netty的線程模型?
-
TCP 粘包/拆包的原因及解決方法?
-
瞭解哪幾種序列化協議?
-
如何選擇序列化協議?
-
Netty的零拷貝實現?
-
Netty的高性能表現在哪些方面?
-
NIOEventLoopGroup源碼?
Redis 16題
-
什麼是redis?
-
Reids的特點
-
Redis支持的數據類型
-
Redis是單進程單線程的
-
虛擬內存
-
Redis鎖
-
讀寫分離模型
-
數據分片模型
-
Redis的回收策略
-
使用Redis有哪些好處?
-
redis相比memcached有哪些優勢?4
-
redis常見性能問題和解決方案
-
MySQL裏有2000w數據,redis中只存20w的數據,如何保證redis中的數據都是熱點數據245
-
Memcache與Redis的區別都有哪些?
-
Redis 常見的性能問題都有哪些?如何解決?
-
Redis 最適合的場景