前言:
CSDN首發!在各大IT交流平臺上都搜索不到的最新最完整詳細的Java面試題檔案,文章概括:
“Spring+JVM+Spring Boot+Dubbo+MySQL+Redis+Linux+并發面試”,足夠詳細!足夠完整!足夠精選!沒有那么多糟粕,留下的都是精華!行與不行,看完說話!
Spring 面試專題
Spring 框架是一個為 Java 應用程式的開發提供了綜合、廣泛的基礎性支持的 Java 平臺,
- 什么是 Spring 框架?Spring 框架有哪些主要模塊?
- 使用 Spring 框架能帶來哪些好處?
- 什么是控制反轉(IOC)?什么是依賴注入?
- 請解釋下 Spring 框架中的 IoC?
- BeanFactory 和 ApplicationContext 有什么區別?
- Spring 有幾種配置方式?
- 如何用基于 XML 配置的方式配置 Spring?
- 如何用基于 Java 配置的方式配置 Spring?
- 怎樣用注解的方式配置 Spring?
- 請解釋 Spring Bean 的生命周期?
- Spring Bean 的作用域之間有什么區別?
- 什么是 Spring inner beans?
- Spring 框架中的單例 Beans 是執行緒安全的么?
- 請舉例說明如何在 Spring 中注入一個 Java Collection?
- 如何向 Spring Bean 中注入一個 Java.util.Properties?
- 請解釋 Spring Bean 的自動裝配?
- 請解釋自動裝配模式的區別?
- 如何開啟基于注解的自動裝配?
- 請舉例解釋@Required 注解?
- 請舉例解釋@Autowired 注解?
- 請舉例說明@Qualifier 注解?
- 構造方法注入和設值注入有什么區別?
- Spring 框架中有哪些不同型別的事件?
- FileSystemResource 和 ClassPathResource 有何區別?
- Spring 框架中都用到了哪些設計模式?

Spring Boot 面試專題
- 什么是 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 微服務?

JVM 面試專題
JVM是一種用于計算設備的規范,它是一個虛構出來的計算機,是通過在實際的計算機上仿真模擬各種計算機功能來實作的,
- 記憶體模型以及磁區,需要詳細到每個區放什么,
- 堆里面的磁區:Eden,survival (from+ to),老年代,各自的特點,
- 物件創建方法,物件的記憶體分配,物件的訪問定位,
- GC 的兩種判定方法:
- SafePoint 是什么
- GC 的三種收集方法:標記清除、標記整理、復制演算法的原理與特點,分別用在什么地方,如果讓你優化收集方法,有什么思路?
- GC 收集器有哪些?CMS 收集器與 G1 收集器的特點,
- Minor GC 與 Full GC 分別在什么時候發生?
- 幾種常用的記憶體除錯工具:jmap、jstack、jconsole、jhat
- 類加載的幾個程序:
- JVM 記憶體分哪幾個區,每個區的作用是什么?
- 如和判斷一個物件是否存活?(或者 GC 物件的判定方法)
- 簡述 java 垃圾回識訓制?
- java 中垃圾收集的方法有哪些?
- java 記憶體模型
- java 類加載程序?
- 簡述 java 類加載機制?
- 類加載器雙親委派模型機制?
- 什么是類加載器,類加載器有哪些?
- 簡述 java 記憶體分配與回收策率以及 Minor GC 和 Major GC

Dubbo 面試專題
Dubbo是國內最出名的分布式服務框架,也是 Java 程式員必備的必會的框架之,
- dubbo 服務集群配置(集群容錯模式)
- dubbo 通信協議 dubbo 協議為什么要消費者比提供者個數多:
- dubbo 通信協議 dubbo 協議為什么不能傳大包:
- dubbo 通信協議 dubbo 協議為什么采用異步單一長連接:
- dubbo 通信協議 dubbo 協議適用范圍和適用場景
- RMI 協議
- Hessian 協議
- http
- Webservice
- Thrif
- Dubbo 中 zookeeper 做注冊中心,如果注冊中心集群都掛掉,發布者和訂閱者之間還能通信么?
- dubbo 服務負載均衡策略?
- Dubbo 在安全機制方面是如何解決的
- dubbo 連接注冊中心和直連的區別

MySQL 面試專題
MySQL是一種關系型資料庫管理系統,關系資料庫將資料保存在不同的表中,而不是將所有資料放在一個大倉庫內,這樣就增加了速度并提高了靈活性,
- 資料庫三范式是什么?
- 有哪些資料庫優化方面的經驗?
- 請簡述常用的索引有哪些種類?
- 以及在 mysql 資料庫中索引的作業機制是什么?
- MySQL 的基礎操作命令:
- mysql 的復制原理以及流程,
- mysql 支持的復制型別?
- mysql 中 myisam 與 innodb 的區別?
- mysql 中 varchar 與 char 的區別以及 varchar(50)中的 50 代表的涵義?
- MySQL 中 InnoDB 支持的四種事務隔離級別名稱,以及逐級之間的區別?
- 表中有大欄位 X(例如:text 型別),且欄位 X 不會經常更新,以讀為為主,將該欄位拆成子表好處是什么?
- MySQL 中 InnoDB 引擎的行鎖是通過加在什么上完成(或稱實作)的?
- MySQL 中控制記憶體分配的全域引數,有哪些?
- 若一張表中只有一個欄位 VARCHAR(N)型別,utf8 編碼,則 N 最大值為多少(精確到數量級即可)
- [SELECT *] 和[SELECT 全部欄位]的 2 種寫法有何優缺點?
- HAVNG 子句 和 WHERE 的異同點?
- MySQL 當記錄不存在時 insert,當記錄存在時 update,陳述句怎么寫?
- MySQL 的 insert 和 update 的 select 陳述句語法

Redis 面試專題
Redis即遠程字典服務,是一個開源的使用ANSI C語言撰寫、支持網路、可基于記憶體亦可持久化的日志型、Key-Value資料庫,并提供多種語言的API,
- 什么是 Redis?簡述它的優缺點?
- Redis 與 memcached 相比有哪些優勢?
- Redis 支持哪幾種資料型別?
- Redis 主要消耗什么物理資源?
- Redis 有哪幾種資料淘汰策略?
- Redis 官方為什么不提供 Windows 版本?
- 為什么 Redis 需要把所有資料放到記憶體中?
- Redis 集群方案應該怎么做?都有哪些方案?
- Redis 集群方案什么情況下會導致整個集群不可用?
- MySQL 里有 2000w 資料,redis 中只存 20w 的資料,如何保證 redis 中的資料都是熱點資料?
- redis 記憶體資料集大小上升到一定大小的時候,就會施行資料淘汰策略,
- Redis 有哪些適合的場景?
- Redis 支持的 Java 客戶端都有哪些?官方推薦用哪個?
- Redis 和 Redisson 有什么關系?
- Jedis 與 Redisson 對比有什么優缺點?
- 說說 Redis 哈希槽的概念?
- Redis 集群的主從復制模型是怎樣的?
- Redis 集群會有寫操作丟失嗎?為什么?
- Redis 集群之間是如何復制的?
- Redis 集群最大節點個數是多少?
- Redis 集群如何選擇資料庫?
- Redis 中的管道有什么用?
- 怎么理解 Redis 事務?
- Redis 事務相關的命令有哪幾個?
- Redis key 的過期時間和永久有效分別怎么設定?
- Redis 如何做記憶體優化?
- Redis 回收行程如何作業的?
- 加鎖機制
- 鎖互斥機制
- watch dog 自動延期機制
- 可重入加鎖機制
- 釋放鎖機制
- 上述 Redis 分布式鎖的缺點
- 使用過 Redis 分布式鎖么,它是怎么實作的?
- 使用過 Redis 做異步佇列么,你是怎么用的?有什么缺點?
- 什么是快取穿透?如何避免?什么是快取雪崩?何如避免?

Linux 面試專題
Linux,全稱GNU/Linux,是一套免費使用和自由傳播的類UNIX作業系統
- Linux 中主要有哪幾種內核鎖?
- Linux 中的用戶模式和內核模式是什么含意?
- 怎樣申請大塊內核記憶體?
- 用戶行程間通信主要哪幾種方式?
- 通過伙伴系統申請內核記憶體的函式有哪些?
- Linux 虛擬檔案系統的關鍵資料結構有哪些?(至少寫出四個)
- 對檔案或設備的操作函式保存在那個資料結構中?
- Linux 中的檔案包括哪些?
- 創建行程的系統呼叫有那些?
- 呼叫 schedule()進行行程切換的方式有幾種?
- Linux 調度程式是根據行程的動態優先級還是靜態優先級來調度行程的?
- 行程調度的核心資料結構是哪個?
- 如何加載、卸載一個模塊?
- 模塊和應用程式分別運行在什么空間?
- Linux 中的浮點運算由應用程式實作還是內核實作?
- 模塊程式能否使用可鏈接的庫函式?
- TLB 中快取的是什么內容?
- Linux 中有哪幾種設備?
- 字符設備驅動程式的關鍵資料結構是哪個?
- 設備驅動程式包括哪些功能函式?
- 如何唯一標識一個設備?
- Linux 通過什么方式實作系統呼叫?
- Linux 軟中斷和作業佇列的作用是什么?

并發面試專題
所謂并發編程是指在一臺處理器上“同時”處理多個任務,并發是在同一物體上的多個事件,多個事件在同一時間間隔發生,
Synchronized 相 關 問 題
問 題 一 : Synchronized 用過嗎,其原理是什么?
問 題 二 : 你剛才提到獲取物件的鎖,這個 “ 鎖 ” 到底是什么?如何確定物件的鎖?
問 題 三 : 什么是可重入性,為什么說Synchronized是可重入鎖?
問 題 四 : JVM對Java的原生鎖做了哪些優化?
問 題 五 : 為什么說Synchronized是非公平鎖?
問 題 六 : 什么是鎖消除和鎖粗化?
問 題 七 : 為什么說Synchronized是一個悲觀鎖?樂觀鎖的實作原理又是什么?什么是CAS,它有什么特性?
問 題 八 : 樂觀鎖一定就是好的嗎?
可重入鎖ReentrantLock及其他顯式鎖相關問題
問 題 一 :跟 Synchronized 相比, 可重入鎖 ReentrantLock 其實作原理有什么不同?
問 題 二 : 那么請談談 AQS 框架是怎么回事兒?
問 題 三 : 請盡可能詳盡地對比下 Synchronized 和 ReentrantLock 的異同,
問 題 四 : ReentrantLock 是如何實作可重入性的?
問 題 五 : 除了 ReetrantLock,你還接觸過 JUC 中的哪些并發工具?
問 題 六 : 請談談 ReadWriteLock 和 StampedLock,
問 題 七 : 如何讓 Java 的執行緒彼此同步?你了解過哪些同步器? 請分別介紹下,
問 題 八 : CyclicBarrier 和 CountDownLatch 看起來很相似,請對比下呢?
Java 線 程 池 相 關 問 題
問 題 一 : Java 中的執行緒池是如何實作的?
問 題 二 : 創建執行緒池的幾個核心構造引數?
問 題 三 : 執行緒池中的執行緒是怎么創建的?是一開始就隨著執行緒池的啟動創建好的嗎?
問 題 四 : 既然提到可以通過配置不同引數創建出不同的執行緒池,那么 Java 中默認實作好的執行緒池又有哪些呢?請比較它們的異同,
問 題 五 : 如何在 Java 執行緒池中提交執行緒?
Java 記憶體模型相關問題
問 題 一 : 什么是 Java 的記憶體模型, Java 中各個執行緒是怎么彼此看到對方的變數的?
問 題 二 : 請談談 volatile 有什么特點,為什么它能保證變數對所有執行緒的可見性?
問 題 三 : 既然 volatile 能夠保證執行緒間的變數可見性,是不是就意味著基于 volatile 變數的運算就是并發安全的?
問 題 四 : 請對比下 volatile 對比 Synchronized 的異同,
問 題 五 : 請談談 ThreadLocal 是怎么解決并發安全的?
問 題 六 : 很多人都說要慎用 ThreadLocal,談談你的理解,使用 ThreadLocal 需要注意些什么?

由于文章篇幅原因,這里只展示了部分檔案和答案,需要完整面試資料的,三連后“加我助理VX”即可免費獲取到

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/166708.html
標籤:其他

