** 金九銀十的面試旺季即將到來,你們準備的怎麼樣了?**java
今年的處境你們都挺難的,可是也不要所以而墮落,太閒了,就多刷題、堅持學習總歸是對本身有好處的.mysql
在此,整理了下金九銀十的面試知識點(附答案),分享出來給各位朋友看下,固然這只是部分資料,你們能夠稍微借鑑下,便可.
面試
第一部分 Java相關
1.1 JAVA基礎
- 面向對象和麪向過程的區別
- Java 語言有哪些特色
- 關於 JVM JDK 和 JRE 最詳細通俗的解答
- Oracle JDK 和 OpenJDK 的對比
- List 和 Set 的區別
- 什麼是 Java 程序的主類 應用程序和小程序的主類有何不一樣
- Java 應用程序與小程序之間有那些差異
- 字符型常量和字符串常量的區別
- Java 面向對象編程三大特性: 封裝 繼承 多態
- 構造器 Constructor 是否可被 override
- Arrays.sort 實現原理和 Collection 實現原理
- 重載和重寫的區別
- String StringBuffer 和 StringBuilder 的區別是什麼? String 爲何是不可變的?
- 在一個靜態方法內調用一個非靜態成員爲何是非法的?
- 在 Java 中定義一個不作事且沒有參數的構造方法的做用
- import java 和 和 javax 有什麼區別?
- 建立一個對象用什麼運算符? 對象實體與對象引用有何不一樣?
- HashMap 1.7 與 1.8 的 區別,說明 1.8 作了哪些優化,如何優化的?
- 接口和抽象類的區別是什麼?
- 成員變量與局部變量的區別有那些?
- 一個類的構造方法的做用是什麼若一個類沒有聲明構造方法, 該程序能正確執行嗎 ? 爲何?
- 構造方法有哪些特性?
- 靜態方法和實例方法有何不一樣
- 對象的相等與指向他們的引用相等,二者有什麼不一樣?
- 在調用子類構造方法以前會先調用父類沒有參數的構造方法,其目的是?
- == 與 equals(重要)
- hashCode 與 equals (重要)
- 爲何 Java 中只有值傳遞?
- 簡述線程,程序、進程的基本概念。以及他們之間關係是什麼?
- 線程有哪些基本狀態?
- Java 中的異常處理?
- 異常分類以及處理機制
- final finally finalize
- 強引用 、軟引用、 弱引用、虛引用
- Java 序列化中若是有些字段不想進行序列化 怎麼辦?
- 獲取用鍵盤輸入經常使用的的兩種方法?
1.2 JAVA併發
- Synchronized 用 過 嗎 , 其 原 理 是 什 麼 ?
- 你 剛 才 提 到 獲 取 對 象 的 鎖,這 個 「鎖」到 底 是 什 麼 ? 如 何 確 定對 象 的 鎖 ?
- 什 麼 是 可 重 入 性 , 爲 什 麼 說 Synchronized 是 可 重 入 鎖 ?
- JVM 對 Java 的 原 生 鎖 作 了 哪 些 優 化 ?
- 爲 什 麼 說 Synchronized 是 非 公 平 鎖 ?
- 什 麼 是 鎖 消 除 和 鎖 粗 化 ?
- 爲 什 麼 說 Synchronized 是 一 個 悲 觀 鎖 ? 樂 觀 鎖 的 實 現 原 理
- 又 是 什 麼 ? 什 麼 是 CAS, 它 有 什 麼 特 性 ?
- 既 然 提 到 可 以 通 過 配 置 不 同 參 數 創 建 出 不 同 的 線 程 池 , 那 麼Java 中 默 認 實 現 好 的 線 程 池 又 有 哪 些 呢 ? 請 比 較 它 們 的 異 同 。
- 如 何 在 Java 線 程 池 中 提 交 線 程 ?
- 什 麼 是 Java 的 內 存 模 型,Java 中 各 個 線 程 是 怎 麼 彼 此 看 到對 方 的 變 量 的 ?
- 請 談 談 volatile 有 什 麼 特 點 , 爲 什 麼 它 能 保 證 變 量 對 所 有 線程 的 可 見 性 ?
- 既 然 volatile 能 夠 保 證 線 程 間 的 變 量 可 見 性 , 是 不 是 就 意 味着 基 於 volatile 變 量 的 運 算 就 是 並 發 安 全 的 ?
- 請 對 比 下 volatile 對 比 Synchronized 的 異 同 。
- 很 多 人 都 說 要 慎 用 ThreadLocal, 談 談 你 的 理 解 , 使 用
- 樂 觀 鎖 一 定 就 是 好 的 嗎 ?
- 跟 Synchronized 相 比 , 可 重 入 鎖 ReentrantLock 其 實 現原 理 有 什 麼 不 同 ?
- 那 麼 請 談 談 AQS 框 架 是 怎 麼 回 事 兒 ?
- 請 盡 可 能 詳 盡 地 對 比 下 Synchronized 和 ReentrantLock的 異 同 。
- ReentrantLock 是 如 何 實 現 可 重 入 性 的 ?
- 除 了 ReetrantLock, 你 還 接 觸 過 JUC 中 的 哪 些 並 發 工 具 ?
- 請 談 談 ReadWriteLock 和 StampedLock。
- 如 何 讓 Java 的 線 程 彼 此 同 步 ? 你 了 解 過 哪 些 同 步 器 ? 請 分 別介 紹 下 。
- CyclicBarrier 和 CountDownLatch 看 起 來 很 相 似 , 請 對 比下 呢 ?
- Java 中 的 線 程 池 是 如 何 實 現 的 ?
- 創 建 線 程 池 的 幾 個 核 心 構 造 參 數 ?
- 線 程 池 中 的 線 程 是 怎 麼 創 建 的 ? 是 一 開 始 就 隨 着 線 程 池 的 啓 動創 建 好 的 嗎 ?
JAVA併發:答案
redis
第二部分 Spring相關
1.1 Spring
- 什麼是 Spring 框架?Spring 框架有哪些主要模塊?
- 使用 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 註解?
- 構造方法注入和設值注入有什麼區別?
- FileSystemResource 和 和 ClassPathResource 有何區別?
- BeanFactory 和 FactoryBean
- Spring IOC 的理解,其初始化過程?
- BeanFactory 和 ApplicationContext?
- Spring Bean 的生命週期,如何被管理的?Spring Bean 的加載過程是怎樣的?
- 若是要你實現Spring AOP,請問怎麼實現?
- 若是要你實現Spring IOC,你會注意哪些問題?
- Spring 是如何管理事務的,事務管理機制?
- Spring 的不一樣事務傳播行爲有哪些,幹什麼用的?
- Spring 中用到了那些設計模式?
- Spring MVC 的工做原理?
- Spring 循環注入的原理?
- Spring 如何保證 Controller 併發的安全?
Spring:答案
算法
2.2 Spring Boot
- 什麼是 Spring Boot?
- Spring Boot 有哪些優勢?
- 什麼是 JavaConfig?
- 如何從新加載 Spring Boot 上的更改,而無需從新啓動服務器?
- Spring Boot 中的監視器是什麼?
- 如何在 Spring Boot 中禁用 Actuator 端點安全性?
- 如何在自定義端口上運行 Spring Boot 應用程序?
- 什麼是 YAML?
- 什麼是 Spring Profiles?
- 什麼是 Spring Batch?
- 如何集成 Spring Boot 和 ActiveMQ?
- 如何使用 Spring Boot 實現分頁和排序?
- 什麼是 Swagger?你用 Spring Boot 實現了它嗎?
- 什麼是 FreeMarker 模板?
- 如何使用 Spring Boot 實現異常處理?
- 您使用了哪些 starter maven 依賴項?
- 什麼是 CSRF 攻擊?
- 什麼是 WebSockets?
- 什麼是 AOP?
- 什麼是 Apache Kafka?
- 咱們如何監視全部 Spring Boot 微服務?
Spring Boot:答案
spring
2.3 Spring MVC
- 什麼是 SpringMvc?
- Spring MVC 的優勢:
- SpringMVC 工做原理?
- SpringMVC 流程?
- SpringMvc 的控制器是否是單例模式,若是是,有什麼問題,怎麼解決?
- 若是你也用過 struts2.簡單介紹下 springMVC 和 struts2 的區別有哪些?
- SpingMvc 中的控制器的註解通常用那個,有沒有別的註解能夠替代?
- @RequestMapping 註解用在類上面有什麼做用?
- 怎麼樣把某個請求映射到特定的方法上面?
- 若是在攔截請求中,我想攔截 get 方式提交的方法,怎麼配置?
- 怎麼樣在方法裏面獲得 Request,或者 Session?
- 我想在攔截的方法裏面獲得從前臺傳入的參數,怎麼獲得?
- 若是前臺有不少個參數傳入,而且這些參數都是一個對象的,那麼怎麼樣快速獲得這個對象?
- SpringMvc 中函數的返回值是什麼?
- SpringMVC 怎麼樣設定重定向和轉發的?
- SpringMvc 用什麼對象從後臺向前臺傳遞數據的?
- SpringMvc 中有個類把視圖和數據都合併的一塊兒的,叫什麼?
- 怎麼樣把 ModelMap 裏面的數據放入 Session 裏面?
- SpringMvc 怎麼和 AJAX 相互調用的?
- 講下 SpringMvc 的執行流程
- SpringMvc 裏面攔截器是怎麼寫的?
- 當一個方法向 AJAX 返回特殊對象,譬如 Object,List 等,須要作什麼處理?
Spring MVC:答案
sql
2.4 Spring Cloud
- 什麼是 Spring Cloud?
- 使用 Spring Cloud 有什麼優點?
- 服務註冊和發現是什麼意思?Spring Cloud 如何實現?
- 負載平衡的意義什麼?
- 什麼是 Hystrix?它如何實現容錯?
- 什麼是 Hystrix 斷路器?咱們須要它嗎?
- 什麼是 Spring Cloud Bus?咱們須要它嗎?
- 什麼是 Netflix Feign?它的優勢是什麼?
Spring Cloud:答案
數據庫
第三部分 數據庫相關
3.1 MySQL高頻面試知識點
- 事務四大特性(ACID)原子性、一致性、隔離性、持久性?
- 事務的併發?事務隔離級別,每一個級別會引起什麼問題,MySQL默認是哪一個級別?
- MySQL常見的三種存儲引擎(InnoDB、MyISAM、MEMORY)的區別?
- MySQL的MyISAM與InnoDB兩種存儲引擎在,事務、鎖級別,各自的適用場景?
- 查詢語句不一樣元素(where、jion、limit、group by、having等等)執行前後順序?
- 什麼是臨時表,臨時表何時刪除?
- MySQL B+Tree索引和Hash索引的區別?
- sql查詢語句肯定建立哪一種類型的索引?如何優化查詢?
- 彙集索引和非彙集索引區別?
- 有哪些鎖(樂觀鎖悲觀鎖),select 時怎麼加排它鎖?
- 非關係型數據庫和關係型數據庫區別,優點比較?
- 數據庫三範式,根據某個場景設計數據表?
- 數據庫的讀寫分離、主從複製,主從複製分析的 7 個問題?
- 使用explain優化sql和索引?
- MySQL慢查詢怎麼解決?
- 什麼是 內鏈接、外鏈接、交叉鏈接、笛卡爾積等?
- mysql都有什麼鎖,死鎖斷定原理和具體場景,死鎖怎麼解決?
- varchar和char的使用場景?
- mysql 高併發環境解決方案?
- 數據庫崩潰時事務的恢復機制(REDO日誌和UNDO日誌)?
MySQL高頻面試知識點:答案
編程
3.2 MySQL性能調優實踐
- 爲查詢緩存優化你的查詢
- EXPLAIN你的SELECT查詢
- 當只要一行數據時使用LIMIT 1
- 爲搜索字段建索引
- 在Join表的時候使用至關類型的例,並將其索引
- 千萬不要 ORDER BY RAND()
- 避免 SELECT *
- 永遠爲每張表設置一個 ID
- 使用 ENUM 而不是 VARCHAR
- 從 PROCEDURE ANALYSE() 取得建議
- 儘量的使用 NOT NULL
- Prepared Statements
- 無緩衝的查詢
- 把 IP 地址存成 UNSIGNED INT
- 固定長度的表會更快
- 垂直分割
- 拆分大的 DELETE 或 INSERT 語句
- 越小的列會越快
- 選擇正確的存儲引擎
- 使用一個對象關係映射器(Object Relational Mapper)
- 當心「永久連接」
- 爲查詢緩存優化你的查詢
- EXPLAIN你的SELECT查詢
- 當只要一行數據時使用LIMIT 1
- 爲搜索字段建索引
- 在Join表的時候使用至關類型的例,並將其索引
- 千萬不要 ORDER BY RAND()
- 避免 SELECT *
- 永遠爲每張表設置一個 ID
- 使用 ENUM 而不是 VARCHAR
- 從 PROCEDURE ANALYSE() 取得建議
- 儘量的使用 NOT NULL
- Prepared Statements
- 無緩衝的查詢
- 把 IP 地址存成 UNSIGNED INT
- 固定長度的表會更快
- 垂直分割
- 拆分大的 DELETE 或 INSERT 語句
- 越小的列會越快
- 選擇正確的存儲引擎
- 使用一個對象關係映射器(Object Relational Mapper)
- 當心「永久連接」
MySQL性能調優實踐答案
第四部分 Redis
- redis 簡介
- 爲何要用 redis /爲何要用緩存(高性能、高併發)
- 爲何要用 redis 而不用 map/guava 作緩存?
- redis 和 memcached 的區別
- redis 常見數據結構以及使用場景分析(String、Hash、List、Set、Sorted Set)
- redis 設置過時時間
- redis 內存淘汰機制(MySQL裏有2000w數據,Redis中只存20w的數據,如何保證Redis中的數據都是熱點數據?)
- redis 持久化機制(怎麼保證 redis 掛掉以後再重啓數據能夠進行恢復)
- redis 事務
- Redis 常見異常及解決方案(緩存穿透、緩存雪崩、緩存預熱、緩存降級)
- 分佈式環境下常見的應用場景(分佈式鎖、分佈式自增 ID)
- Redis 集羣模式(主從模式、哨兵模式、Cluster 集羣模式)
- 如何解決 Redis 的併發競爭 Key 問題
- 如何保證緩存與數據庫雙寫時的數據一致性?
Redis:答案
小程序
第五部分 分佈式相關
- Dubbo的底層實現原理和機制
- 描述一個服務從發佈到被消費的詳細過程
- 分佈式系統怎麼作服務治理
- 接口的冪等性的概念
- 消息中間件如何解決消息丟失問題
- Dubbo的服務請求失敗怎麼處理
- 重連機制會不會形成錯誤
- 對分佈式事務的理解
- 如何實現負載均衡,有哪些算法能夠實現?
- Zookeeper的用途,選舉的原理是什麼?
- 數據的垂直拆分水平拆分。
- zookeeper原理和適用場景
- zookeeper watch機制
- redis/zk節點宕機如何處理
- 分佈式集羣下如何作到惟一序列號
- 如何作一個分佈式鎖
- 用過哪些MQ,怎麼用的,和其餘mq比較有什麼優缺點,MQ的鏈接是線程安全的嗎
- MQ系統的數據如何保證不丟失
- 列舉出你能想到的數據庫分庫分表策略;分庫分表後,如何解決全表查詢的問題
- zookeeper的選舉策略
第六部分 JVM
- JVM 內存結構
- HotSpot 虛擬機對象探祕
- 垃圾收集策略與算法
- HotSpot 垃圾收集器
- 內存分配與回收策略
- JVM 性能調優
- 類文件結構
- 類加載的時機
- 類加載的過程
- 類加載器
JVM:答案
第七部分 算法
- 編程技巧
- 線性表
- 字符串
- 棧和隊列
- 樹
- 排序
- 查找
- 暴力枚舉法
- 廣度優先搜素
- 深度優先搜素
- 分治法
- 貪心法
- 動態規劃
- 圖
- 細節實現題
算法:答案
除了上面的知識點,還準備了一些必問面試題,收集了各方面的,當前公司的,還有本身收集總結的,下面的圖片截取的有pdf,有若是有須要的自取.
各大公司面試題集合:
簡歷模板:
提取碼:fgj6
不知道會不會失效,若是失效點擊(778490892)或者掃描下面二維碼,進羣獲取,連接補發不過來,謝謝。