絞盡腦汁我掏空了各大搜尋引擎,耗時10個月給你整理了209道Java面試題含答案,滿滿乾貨記得收藏再看

2020-10-09 11:00:25

答案獲取方式:


Java集合19題

這個算是java中的基礎題吧,但是不要小看這些題,有一些可能都回答不上來。我發現最近關於底層問題問的越來越多了,這也算一個基本線吧,如果回答不上來就涼涼了。

 

  • 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 集合類框架的最佳實踐有哪些?

JVM與調優18題

JVM算是去大廠必會的一個知識點了,效能調優問題、垃圾回收機制、雙親委派以及體系結構,這些會的越多加分就越多。

  • Java 類載入過程?
  • 描述一下 JVM 載入 Class 檔案的原理機制?
  • Java 記憶體分配。
  • GC 是什麼? 為什麼要有 GC?
  • 簡述 Java 垃圾回收機制
  • 如何判斷一個物件是否存活?(或者 GC 物件的判定方法)
  • 垃圾回收的優點和原理。並考慮 2 種回收機制
  • 垃圾回收器的基本原理是什麼?垃圾回收器可以馬上回收記憶體嗎?有什麼辦法主動通知虛擬機器器進行垃圾回收?
  • Java 中會存在記憶體漏失嗎,請簡單描述
  • 深拷貝和淺拷貝。
  • System.gc() 和 Runtime.gc() 會做什麼事情?
  • finalize() 方法什麼時候被呼叫?解構函式 (finalization) 的目的是什麼?
  • 如果物件的參照被置為 null,垃圾收集器是否會立即釋放物件佔用的記憶體?
  • 序列(serial)收集器和吞吐量(throughput)收集器的區別是什麼?
  • 在 Java 中,物件什麼時候可以被垃圾回收?
  • 簡述 Java 記憶體分配與回收策略以及 Minor GC 和 Major GC。
  • VM 的永久代中會發生垃圾回收麼?

並行程式設計24題

並行是重點的重點,記得有一次面試關於並行問題面試官死磕了我半個小時,從鎖機制到執行緒池被安排的明明白白的。

  • Synchronized 用過嗎,其原理是什麼?
  • 你剛才提到獲取物件的鎖,這個「鎖」到底是什麼?如何確定物件的鎖?
  • 什麼是可重入性,為什麼說 Synchronized 是可重入鎖?
  • VM 對 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 有什麼特點,為什麼它能保證變數對所有執行緒的可見性?

spring 22題

我相信大家都用過Spring吧,身為開源框架他的重要性毋庸置疑,IOC、AOP兩大必問核心,從註解到標籤都有可能問到。

  • 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、構造方法注入和設值注入有什麼區別?

設計模式 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題

最近springboot和springcloud的佔比越來越重,因為他們最受中小企業歡迎,學會了它們最低也餓不死了哈哈。

  • 什麼是 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 微服務?

Spring Cloud 8題

  • 什麼是 Spring Cloud?
  • 使用 Spring Cloud 有什麼優勢?
  • 服務註冊和發現是什麼意思?Spring Cloud 如何實現?
  • 負載平衡的意義什麼?
  • 什麼是 Hystrix?它如何實現容錯?
  • 什麼是 Hystrix 斷路器?我們需要它嗎?
  • 什麼是 Netflix Feign?它的優點是什麼?
  • 什麼是 Spring Cloud Bus?我們需要它嗎?

Redis 8題

Redis的資料特點以及回收策略是很重要的一部分,它的優勢以及使用場景都需要了解一下

  • 什麼是redis?
  • Reids的特點
  • Redis支援的資料型別
  • Redis是單程序單執行緒的
  • 虛擬記憶體
  • Redis鎖
  • 讀寫分離模型
  • 資料分片模型

一線網際網路企業精品面試題73道

  • junit 用法,before,beforeClass,after, afterClass 的執行順序
  • 分散式鎖
  • nginx 的請求轉發演演算法,如何設定根據權重轉發
  • 用 hashmap 實現 redis 有什麼問題(死鎖,死迴圈,可用 ConcurrentH ashmap)
  • 執行緒的狀態
  • 執行緒的阻塞的方式
  • sleep 和 wait 的區別
  • hashmap 的底層實現
  • 一萬個人搶 100 個紅包,如何實現(不用佇列),如何保證 2 個人不能搶到同一個紅包,可用分散式鎖
  • java 記憶體模型,垃圾回收機制,不可達演演算法
  • 兩個 Integer 的參照物件傳給一個 swap 方法在方法內部交換參照,返回後,兩個參照的值是否會發現變化
  • aop 的底層實現,動態代理是如何動態,假如有 100 個物件,如何動態 的為這 100 個物件代理
  • 是否用過 maven install。 maven test。git(make install 是安裝本地 jar 包)
  • tomcat 的各種設定,如何設定 docBase
  • spring 的 bean 設定的幾種方式
  • web.xml 的設定
  • spring 的監聽器。
  • zookeeper 的實現機制,有快取,如何儲存註冊服務的
  • IO 會阻塞嗎?readLine 是不是阻塞的
  • 用過 spring 的執行緒池還是 java 的執行緒池?
  • 字串的格式化方法 (20,21 這兩個問題問的太低階了)
  • 時間的格式化方法
  • 定時器用什麼做的
  • 執行緒如何退出結束
  • java 有哪些鎖?樂觀鎖 悲觀鎖 synchronized 可重入鎖 讀寫鎖,用過 reentrantlock 嗎?reentrantlock 與 synmchronized 的區別
  • ThreadLocal 的使用場景
  • java 的記憶體模型,垃圾回收機制
  • 為什麼執行緒執行要呼叫 start 而不是直接 run(直接 run,跟普通方法沒 什麼區別,先調 start,run 才會作為一個執行緒方法執行)
  • qmq 訊息的實現機制(qmq 是去哪兒網自己封裝的訊息佇列)
  • 遍歷 hashmap 的三種方式
  • jvm 的一些命令31. memcache 和 redis 的區別
  • mysql 的行級鎖加在哪個位置
  • ConcurrentHashmap 的鎖是如何加的?是不是分段越多越好
  • myisam 和 innodb 的區別(innodb 是行級鎖,myisam 是表級鎖)
  • mysql 其他的效能優化方式
  • linux 系統紀錄檔在哪裡看
  • 如何檢視網路程序
  • 統計一個整數的二進位制表示中 bit 為 1 的個數
  • jvm 記憶體模型,java 記憶體模型
  • 如何把 java 記憶體的資料全部 dump 出來
  • 如何手動觸發全量回收垃圾,如何立即觸發垃圾回收
  • hashmap 如果只有一個寫其他全讀會出什麼問題
  • mybatis 如何對映表結構
  • 二元樹遍歷
  • 主從複製
  • mysql 引擎區別
  • 靜態內部類載入到了哪個區?方法區
  • class 檔案編譯後載入到了哪
  • web 的 http 請求如何整體響應時間變長導致處理的請求數變少,該如何處理?用佇列,當處理不了那麼多 http 請求時將請求放到佇列中慢慢處理,web 如何實現佇列77. 執行緒安全的單例模式
  • 快速排序效能考慮
  • volatile 關鍵字用法
  • 求表的 size,或做資料統計可用什麼儲存引擎
  • 讀多寫少可用什麼引擎
  • 假如要統計多個表應該用什麼引擎
  • concurrenhashmap 求 size 是如何加鎖的,如果剛求完一段後這段發生了變化該如何處理1000 個蘋果放 10 個籃子,怎麼放,能讓我拿到所有可能的個數可重入的讀寫鎖,可重入是如何實現的?
  • 是否用過 NIO
  • java 的 concurrent 包用過沒
  • sting s=new string("abc")分別在堆疊上新建了哪些物件
  • java 虛擬機器器的區域分配,各區分別存什麼
  • 分散式事務(JTA)91. threadlocal 使用時注意的問題(ThreadLocal 和 Synchonized 都用於解決多執行緒並行存取。但是 ThreadLocal 與 synchronized 有本質的區別。s
  • ynchronized 是利用鎖的機制,使變數或程式碼塊在某一時該只能被一個執行緒存取。而 ThreadLocal 為每一個執行緒都提供了變數的副本,使得每個執行緒在某 一時間存取到的並不是同一個物件,這樣就隔離了多個執行緒對資料的資料共用。而 Synchronized 卻正好相反,它用於在多個執行緒間通訊時能夠獲得資料共用)
  • java 有哪些容器(集合,tomcat 也是一種容器)
  • 二分查詢演演算法
  • myisam 的優點,和 innodb 的區別
  • redis 能存哪些型別
  • http 協定格式,get 和 post 的區別
  • 可重入鎖中對應的 wait 和 notify
  • redis 能把記憶體空間交換進磁碟中嗎(這個應該是可以的,但是那個面試官 非跟我說不可以)
  • java 執行緒池中基於快取和基於定長的兩種執行緒池,當請求太多時分別是如何處理的?定長的事用的佇列,如果佇列也滿了呢?交換進磁碟?基於快取的 執行緒池解決方法呢?
  • synchronized 加在方法上用的什麼鎖101. 可重入鎖中的 lock 和 trylock 的區別
  • innodb 對一行資料的讀會枷鎖嗎?不枷鎖,讀實際讀的是副本
  • redis 做快取是分散式存的?不同的伺服器上存的資料是否重複?guava

 

必考題和答案

 

答案獲取方式

關注+點贊!