八股文

面試題

Java 基礎

  1. JDK 和 JRE 有什么區別?
JDK:jdk 包含jre jvm ,jdk是java開發工具包
JDK:jdk包含jvm,包含java基礎類庫  jdk是java運行環境
  1. == 和 equals 的區別是什么?
==:對比的是基本數據類型的值
equals:底層是==實現,但是對比的是hacode的值
  1. 兩個對象的 hashCode() 相同,則 equals() 也一定為 true,對嗎?
String str1 = "通話";
String str2 = "重地";
System.out.println(String.format("str1:%d | str2:%d", str1.hashCode(),str2.hashCode()));
System.out.println(str1.equals(str2));
結果:
str1:1179395 | str2:1179395
false
  1. final 在 java 中有什么作用?
修飾類:不能被繼承
修飾方法:表示方法不能被重寫;
修飾基本數據類型:需要賦值, 且值固定不能發生改變
修飾引用數據類型:引用地址不能發生改變,值可以修改
  1. java 中的 Math.round(-1.5) 等于多少?
ceil的英文意義是天花板,該方法就表示向上取整
floor的英文意義是地板,該方法就表示向下取整
round方法,它表示“四舍五入”,算法為Math.floor(x+0.5),即將原來的數字加上0.5后再向下取整
  1. String 屬于基礎的數據類型嗎?
不屬于,String屬于引用數據類型,final修飾的類
String類型的字面值是存儲在常量池中
  1. java 中操作字符串都有哪些類?它們之間有什么區別?
String: final修飾,String類的方法都是返回new String。即對String對象的任何改變都不影響到原對象,對字符串的修改操作都會生成新的對象。
StringBuffer:對字符串的操作的方法都加了synchronized,保證線程安全。
StringBuilder:StringBuilder : 不保證線程安全,在方法體內需要進行字符串的修改操作,可以new StringBuilder對象,調用StringBuilder對象的append、replace、delete等方法修改字符串。

Sting修飾的類不能被更改性能更低,占內存量更高 Stringbuffer Stringbuilder 加強了對字符串的操作 可以更改,但是StringBuffer的安全性能高,適合多線程使用,Stringbuider性能更低適合單線程操作
  1. String str="i"與 String str=new String(“i”)一樣嗎?
不一樣,使用String str=“i”,java虛擬機會把它分配到常量池中,而 String str=new String(“i”)創建了一個對象,會被分到堆內存中。
Java為了避免產生大量的String對象,設計了一個字符串常量池。
工作原理是這樣的,創建一個字符串時,JVM首先為檢查字符串常量池中是否有值相等的字符串,如果有,則不再創建,直接返回該字符串的引用地址,
若沒有,則創建,然后放到字符串常量池中,并返回新創建的字符串的引
  1. 如何將字符串反轉?
利用Stringbuffer和Stringbuilder
遞歸

  1. String 類的常用方法都有那些?

  2. 抽象類必須要有抽象方法嗎?

  3. 普通類和抽象類有哪些區別?

  4. 抽象類能使用 final 修飾嗎?

抽象類不能使用final方法, 因為抽象類不能實例化,子類必須實現父類的抽象方法
  1. 接口和抽象類有什么區別?
抽象類有構造方法,接口沒有
抽象類有普通成員變量,接口中的成員變量是默認被final修飾的必須賦值且不能發生改變
抽象類有普通方法,如果接口需要定義普通方法的話需要default修飾
一個類可以實現多個接口,但只能繼承一個抽象類
接口可以多實現,抽象類只能單一繼承
  1. java 中 IO 流分為幾種?

  2. BIO、NIO、AIO 有什么區別?

  3. Files的常用方法都有哪些?

  4. java 容器都有哪些?

容器

  1. Collection 和 Collections 有什么區別?
Collection:集合類的頂級接口
Collections:是集合的工具類,提供了一系列排序查找修改的靜態方法
  1. List、Set、Map 之間的區別是什么?
List:有序能重復 ,可以為空
Set:無序不能重復 ,可以為空
List和Set都實現Collection
Map:map鍵值對映射,鍵值能為空
  1. HashMap 和 Hashtable 有什么區別?

  2. 如何決定使用 HashMap 還是 TreeMap?

  3. 說一下 HashMap 的實現原理?

1.數據結構:數組,鏈表,紅黑樹
初始容量:16
加載因子:0.75
閾值大于12會發生擴容
數組大于64,閾值大于8時樹化成紅黑樹
2:算法:利用hash算法決定k的值和位置
  1. 說一下 HashSet 的實現原理?

  2. ArrayList 和 LinkedList 的區別是什么?

ArrayList:動態數組,查詢速度快,增刪慢
LinkedList:雙向鏈表,查詢速度慢,增刪塊,
  1. 如何實現數組和 List 之間的轉換?

  2. ArrayList 和 Vector 的區別是什么?

  3. Array 和 ArrayList 有何區別?

  4. 在 Queue 中 poll()和 remove()有什么區別?

  5. 哪些集合類是線程安全的?

vector,concurrentHashMap,HashTable,stack
  1. 迭代器 Iterator 是什么?

  2. Iterator 怎么使用?有什么特點?

  3. Iterator 和 ListIterator 有什么區別?

  4. 怎么確保一個集合不能被修改?

多線程

  1. 并行和并發有什么區別?
并行指多個事件在同一個時刻發生;并發指在某時刻只有一個事件在發生,某個時間段內由于 CPU 交替執行,可以發生多個事件。
并行沒有對 CPU 資源的搶占;并發執行的線程需要對 CPU 資源進行搶占。
并行執行的線程之間不存在切換;并發操作系統會根據任務調度系統給線程分配線程的 CPU 執行時間,線程的執行會進行切換。
  1. 線程和進程的區別?
進程:每個進程都有獨立的代碼和數據空間(進程上下文),進程間的切換會有較大的開銷,一個進程包含1--n個線程。(進程是資源分配的最小單位)
線程:同一類線程共享代碼和數據空間,每個線程有獨立的運行棧和程序計數器(PC),線程切換開銷小。(線程是cpu調度的最小單位)
  1. 守護線程是什么?

  2. 創建線程有哪幾種方式?

thread runable callable 線程池
  1. 說一下 runnable 和 callable 有什么區別?
runable:run方法
callable:call方法
  1. 線程有哪些狀態?
    線程和進程一樣分為五個階段:創建、就緒、運行、阻塞、終止。
image
  1. sleep() 和 wait() 有什么區別?
sleep() 方法是線程類(Thread)的靜態方法,讓調用線程進入睡眠狀態,讓出執行機會給其他線程,等到休眠時間結束后,線程進入就緒狀態和其他線程一起競爭cpu的執行時間。

因為sleep() 是static靜態的方法,他不能改變對象的機鎖,當一個synchronized塊中調用了sleep() 方法,線程雖然進入休眠,但是對象的機鎖沒有被釋放,其他線程依然無法訪問這個對象。

wait()是Object類的方法,當一個線程執行到wait方法時,它就進入到一個和該對象相關的等待池,同時釋放對象的機鎖,使得其他線程能夠訪問,可以通過notify,notifyAll方法來喚醒等待的線程

sleep() 和 wait() 的區別就是 調用sleep方法的線程不會釋放對象鎖,而調用wait() 方法會釋放對象鎖

  1. notify()和 notifyAll()有什么區別?

  2. 線程的 run()和 start()有什么區別?

44.創建線程池有哪幾種方式?

newFixedThreadPool
newSingleThreadExector
newCachedThreadPool

45.線程池都有哪些狀態?

1.RUNNING

狀態說明:線程池處在RUNNING狀態時,能夠接收新任務,以及對已添加的任務進行處理。
狀態切換:線程池的初始化狀態是RUNNING。換句話說,線程池被一旦被創建,就處于RUNNING狀態,并且線程池中的任務數為0!
private final AtomicInteger ctl = new AtomicInteger(ctlOf(RUNNING, 0));
2.SHUTDOWN

狀態說明:線程池處在SHUTDOWN狀態時,不接收新任務,但能處理已添加的任務。
狀態切換:調用線程池的shutdown()接口時,線程池由RUNNING -> SHUTDOWN。
3.STOP

狀態說明:線程池處在STOP狀態時,不接收新任務,不處理已添加的任務,并且會中斷正在處理的任務。
狀態切換:調用線程池的shutdownNow()接口時,線程池由(RUNNING or SHUTDOWN ) -> STOP。
4.TIDYING

狀態說明:當所有的任務已終止,ctl記錄的”任務數量”為0,線程池會變為TIDYING狀態。當線程池變為TIDYING狀態時,會執行鉤子函數terminated()。terminated()在ThreadPoolExecutor類中是空的,若用戶想在線程池變為TIDYING時,進行相應的處理;可以通過重載terminated()函數來實現。
狀態切換:當線程池在SHUTDOWN狀態下,阻塞隊列為空并且線程池中執行的任務也為空時,就會由 SHUTDOWN -> TIDYING。
當線程池在STOP狀態下,線程池中執行的任務為空時,就會由STOP -> TIDYING。
5.TERMINATED

狀態說明:線程池徹底終止,就變成TERMINATED狀態。
狀態切換:線程池處在TIDYING狀態時,執行完terminated()之后,就會由 TIDYING -> TERMINATED。
  1. 線程池中 submit()和 execute()方法有什么區別?

  2. 在 java 程序中怎么保證多線程的運行安全?

  3. 多線程鎖的升級原理是什么?

多線程synchronized 鎖升級的原理
synchronized 鎖升級原理:在鎖對象的對象頭里面有一個 threadid 字段,在第一次訪問的時候 threadid 為空,jvm 讓其持有偏向鎖,并將 threadid 設置為其線程 id,再次進入的時候會先判斷 threadid 是否與其線程 id 一致,如果一致則可以直接使用此對象,如果不一致,則升級偏向鎖為輕量級鎖,通過自旋循環一定次數來獲取鎖,執行一定次數之后,如果還沒有正常獲取到要使用的對象,此時就會把鎖從輕量級升級為重量級鎖,此過程就構成了 synchronized 鎖的升級。

鎖的升級的目的
鎖升級是為了減低了鎖帶來的性能消耗。在 Java 6 之后優化 synchronized 的實現方式,使用了偏向鎖升級為輕量級鎖再升級到重量級鎖的方式,從而減低了鎖帶來的性能消耗。
  1. 什么是死鎖?
互斥條件:進程要求對所分配的資源進行排它性控制,即在一段時間內某資源僅為一進程所占用。
請求和保持條件:當進程因請求資源而阻塞時,對已獲得的資源保持不放。
不剝奪條件:進程已獲得的資源在未使用完之前,不能剝奪,只能在使用完時由自己釋放。
環路等待條件:在發生死鎖時,必然存在一個進程--資源的環形鏈。
  1. 怎么防止死鎖?

  2. ThreadLocal 是什么?有哪些使用場景?

  3. 說一下 synchronized 底層實現原理?

  4. synchronized 和 volatile 的區別是什么?

  5. synchronized 和 Lock 有什么區別?

  6. synchronized 和 ReentrantLock 區別是什么?

  7. 說一下 atomic 的原理?

反射

  1. 什么是反射?

  2. 什么是 java 序列化?什么情況下需要序列化?

  3. 動態代理是什么?有哪些應用?

  4. 怎么實現動態代理?

對象拷貝

  1. 為什么要使用克隆?

  2. 如何實現對象克隆?

  3. 深拷貝和淺拷貝區別是什么?

Java Web

  1. jsp 和 servlet 有什么區別?

  2. jsp 有哪些內置對象?作用分別是什么?

  3. 說一下 jsp 的 4 種作用域?

  4. session 和 cookie 有什么區別?

  5. 說一下 session 的工作原理?

  6. 如果客戶端禁止 cookie 能實現 session 還能用嗎?

  7. spring mvc 和 struts 的區別是什么?

  8. 如何避免 sql 注入?

  9. 什么是 XSS 攻擊,如何避免?

  10. 什么是 CSRF 攻擊,如何避免?

異常

  1. throw 和 throws 的區別?
1)throws 用在方法聲明后,跟在后面的是異常類名 (Execution ),throw 用在方法體內,跟的是異常的對象名 (new Execution)。
2)throws 后可以跟多個異常類名,用逗號隔開;而 throw 只能拋出一個異常對象名。
3)throws 表示拋出的異常由該方法調用者處理,throw表示拋出的異常由自己處理(定義方法體內)
4)throws 表示會出現異常的一種可能性,不一定會發生該異常;throw 要是執行了則一定拋出了某種異常且后面的代碼都不執行。
  1. final、finally、finalize 有什么區別?
final:

如果一個類被聲明為 final ,意味著它不能再派生出新的子類,不能作為父類被繼承。因此一個類不能既被聲明為 abstract 的,又被聲明為 final 的。
將變量或方法聲明為 final ,可以保證它們在使用中不被改變。被聲明為 final 的變量必須在聲明時給定初值,而在以后的引用中只能讀取,不可修改。被聲明為 final 的方法也同樣只能使用,不能重寫。
另外,在早期的 Java 實現版本中,會將 final 方法轉為內嵌調用。但是如果方法過于龐大,可能看不到內嵌調用帶來的任何性能提升(現在的 Java 版本已經不需要使用 final 方法進行這些優化了)。類中所有的private 方法都隱式地指定為 final 。
String 、Integer、Long等類都是final修飾的類。其保存值的屬性也是final修飾的。
final修飾基本數據類型和修飾引用數據類型。
如果final修飾的是一個基本數據類型的數據,一旦賦值后就不能再次更改 ,而對于引用類型變量而言,它僅僅保存的是一個引用,final只保證這個引用類型變量所引用的地址不會發生改變,即一直引用這個對象,但這個對象屬性是可以改變的。


finally:
在異常處理時提供 finally 塊來執行任何清除操作。如果拋出一個異常,那么相匹配的 catch 子句就會執行,然后控制就會進入 finally 塊(如果有的話)。
通常在處理一些資源的時候,會使用finally來關閉相關資源。比如說:操作文件,使用ReentrantLock鎖,分布式鎖等。
在以下 4 種特殊情況下,finally塊不會被執行:
在 finally 語句塊中發生了異常。
在前面的代碼中用了 System.exit() 退出程序。
程序所在的線程死亡。
關閉 CPU 。

finalize:
finalize是Object的一個方法,它的目的是保證對象在被垃圾收集前完成特定資源的回收。
不過finalize已經不推薦使用,JDK9已經標記為過時。
  1. try-catch-finally 中哪個部分可以省略?

  2. try-catch-finally 中,如果 catch 中 return 了,finally 還會執行嗎?

會。

(1)finally的作用就是,無論出現什么狀況,finally里的代碼一定會被執行。
(2)如果在catch中return了,也會在return之前,先執行finally代碼塊。
(3)而且如果finally代碼塊中含有return語句,會覆蓋其他地方的return。
(4)對于基本數據類型的數據,在finally塊中改變return的值對返回值沒有影響,而對引用數據類型的數據會有影響。

  1. 常見的異常類有哪些?
RunTime Exception 運行異常
Compilation Exception 編譯異常
InputMisMatch Exception 輸入類型不匹配{有可能是{nextInt異常,數據類型異常}
ArrayIndexOutOfBoundes Exception  數組索引越界
Arithmetiv Exception 算數異常
NullPointException空指針異常
IllegalAccessException:非法侵入異常
ConcurrentModificationException:并發修改異常
PersistenceException:映射文件加載異常

網絡

  1. http 響應碼 301 和 302 代表的是什么?有什么區別?

  2. forward 和 redirect 的區別?

  3. 簡述 tcp 和 udp的區別?

  4. tcp 為什么要三次握手,兩次不行嗎?為什么?

  5. 說一下 tcp 粘包是怎么產生的?

  6. OSI 的七層模型都有哪些?

  7. get 和 post 請求有哪些區別?

  8. 如何實現跨域?

  9. 說一下 JSONP 實現原理?

設計模式

  1. 說一下你熟悉的設計模式?

  2. 簡單工廠和抽象工廠有什么區別?

Spring/Spring MVC

  1. 為什么要使用 spring?

  2. 解釋一下什么是 aop?

  3. 解釋一下什么是 ioc?

  4. spring 有哪些主要模塊?

  5. spring 常用的注入方式有哪些?

  6. spring 中的 bean 是線程安全的嗎?

  7. spring 支持幾種 bean 的作用域?

  8. spring 自動裝配 bean 有哪些方式?

  9. spring 事務實現方式有哪些?

  10. 說一下 spring 的事務隔離?

  11. 說一下 spring mvc 運行流程?

  12. spring mvc 有哪些組件?

  13. @RequestMapping 的作用是什么?

  14. @Autowired 的作用是什么?

依賴注入

Spring Boot/Spring Cloud

  1. 什么是 spring boot?

  2. 為什么要用 spring boot?

  3. spring boot 核心配置文件是什么?

  4. spring boot 配置文件有哪幾種類型?它們有什么區別?

  5. spring boot 有哪些方式可以實現熱部署?

  6. jpa 和 hibernate 有什么區別?

  7. 什么是 spring cloud?

  8. spring cloud 斷路器的作用是什么?

  9. spring cloud 的核心組件有哪些?

Hibernate

  1. 為什么要使用 hibernate?

  2. 什么是 ORM 框架?

  3. hibernate 中如何在控制臺查看打印的 sql 語句?

  4. hibernate 有幾種查詢方式?

  5. hibernate 實體類可以被定義為 final 嗎?

  6. 在 hibernate 中使用 Integer 和 int 做映射有什么區別?

  7. hibernate 是如何工作的?

  8. get()和 load()的區別?

  9. 說一下 hibernate 的緩存機制?

  10. hibernate 對象有哪些狀態?

  11. 在 hibernate 中 getCurrentSession 和 openSession 的區別是什么?

  12. hibernate 實體類必須要有無參構造函數嗎?為什么?

Mybatis

  1. mybatis 中 #{}和 ${}的區別是什么?

  2. mybatis 有幾種分頁方式?

  3. RowBounds 是一次性查詢全部結果嗎?為什么?

  4. mybatis 邏輯分頁和物理分頁的區別是什么?

  5. mybatis 是否支持延遲加載?延遲加載的原理是什么?

  6. 說一下 mybatis 的一級緩存和二級緩存?

  7. mybatis 和 hibernate 的區別有哪些?

  8. mybatis 有哪些執行器(Executor)?

  9. mybatis 分頁插件的實現原理是什么?

  10. mybatis 如何編寫一個自定義插件?

RabbitMQ

  1. rabbitmq 的使用場景有哪些?

  2. rabbitmq 有哪些重要的角色?

  3. rabbitmq 有哪些重要的組件?

  4. rabbitmq 中 vhost 的作用是什么?

  5. rabbitmq 的消息是怎么發送的?

  6. rabbitmq 怎么保證消息的穩定性?

141.rabbitmq 怎么避免消息丟失?

  1. 要保證消息持久化成功的條件有哪些?

  2. rabbitmq 持久化有什么缺點?

  3. rabbitmq 有幾種廣播類型?

  4. rabbitmq 怎么實現延遲消息隊列?

  5. rabbitmq 集群有什么用?

  6. rabbitmq 節點的類型有哪些?

  7. rabbitmq 集群搭建需要注意哪些問題?

  8. rabbitmq 每個節點是其他節點的完整拷貝嗎?為什么?

  9. rabbitmq 集群中唯一一個磁盤節點崩潰了會發生什么情況?

  10. rabbitmq 對集群節點停止順序有要求嗎?

Kafka

  1. kafka 可以脫離 zookeeper 單獨使用嗎?為什么?

  2. kafka 有幾種數據保留的策略?

  3. kafka 同時設置了 7 天和 10G 清除數據,到第五天的時候消息達到了 10G,這個時候 kafka 將如何處理?

  4. 什么情況會導致 kafka 運行變慢?

  5. 使用 kafka 集群需要注意什么?

Zookeeper

  1. zookeeper 是什么?

  2. zookeeper 都有哪些功能?

  3. zookeeper 有幾種部署模式?

  4. zookeeper 怎么保證主從節點的狀態同步?

  5. 集群中為什么要有主節點?

  6. 集群中有 3 臺服務器,其中一個節點宕機,這個時候 zookeeper 還可以使用嗎?

  7. 說一下 zookeeper 的通知機制?

MySql

  1. 數據庫的三范式是什么?

  2. 一張自增表里面總共有 7 條數據,刪除了最后 2 條數據,重啟 mysql 數據庫,又插入了一條數據,此時 id 是幾?

  3. 如何獲取當前數據庫版本?

  4. 說一下 ACID 是什么?

  5. char 和 varchar 的區別是什么?

  6. float 和 double 的區別是什么?

  7. mysql 的內連接、左連接、右連接有什么區別?

  8. mysql 索引是怎么實現的?

  9. 怎么驗證 mysql 的索引是否滿足需求?

  10. 說一下數據庫的事務隔離?

  11. 說一下 mysql 常用的引擎?

  12. 說一下 mysql 的行鎖和表鎖?

  13. 說一下樂觀鎖和悲觀鎖?

  14. mysql 問題排查都有哪些手段?

  15. 如何做 mysql 的性能優化?

Redis

  1. redis 是什么?都有哪些使用場景?

  2. redis 有哪些功能?

  3. redis 和 memecache 有什么區別?

  4. redis 為什么是單線程的?

  5. 什么是緩存穿透?怎么解決?

  6. redis 支持的數據類型有哪些?

  7. redis 支持的 java 客戶端都有哪些?

  8. jedis 和 redisson 有哪些區別?

  9. 怎么保證緩存和數據庫數據的一致性?

  10. redis 持久化有幾種方式?

189.redis 怎么實現分布式鎖?

  1. redis 分布式鎖有什么缺陷?

  2. redis 如何做內存優化?

  3. redis 淘汰策略有哪些?

  4. redis 常見的性能問題有哪些?該如何解決?

JVM

  1. 說一下 jvm 的主要組成部分?及其作用?

  2. 說一下 jvm 運行時數據區?

  3. 說一下堆棧的區別?

  4. 隊列和棧是什么?有什么區別?

  5. 什么是雙親委派模型?

  6. 說一下類加載的執行過程?

  7. 怎么判斷對象是否可以被回收?

  8. java 中都有哪些引用類型?

  9. 說一下 jvm 有哪些垃圾回收算法?

  10. 說一下 jvm 有哪些垃圾回收器?

  11. 詳細介紹一下 CMS 垃圾回收器?

  12. 新生代垃圾回收器和老生代垃圾回收器都有哪些?有什么區別?

  13. 簡述分代垃圾回收器是怎么工作的?

  14. 說一下 jvm 調優的工具?

  15. 常用的 jvm 調優的參數都有哪些?·

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容