Java 最常見的 200+ 面試題:面試必備(加上自己的一點小總結,外加無償分享)

有急需的小夥伴可以直接下載,不墨跡(連接失效,隨時評論,會更新的!!!)

鏈接:https://pan.baidu.com/s/1boi0nPmDxa29L2hgNg2MqQ 
提取碼:li6o 

也可以支持下,用積分下載(ps:我可能也需要積分去下載一些東西,我爲人人,人人爲我)

https://download.csdn.net/download/yuanmomoya/11297077

適宜閱讀人羣

  • 需要面試的初/中/高級 java 程序員
  • 想要查漏補缺的人
  • 想要不斷完善和擴充自己 java 技術棧的人
  • java 面試官

面試題模塊介紹

面試題包含的內容了十九了模塊:Java 基礎、容器、多線程、反射、對象拷貝、Java Web 模塊、異常、網絡、設計模式、Spring/Spring MVC、Spring Boot/Spring Cloud、Hibernate、Mybatis、RabbitMQ、Kafka、Zookeeper、MySql、Redis、JVM 。如下圖所示:
 

 

可能對於初學者不需要後面的框架和 JVM 模塊的知識,讀者朋友們可根據自己的情況,選擇對應的模塊進行閱讀。 

具體面試題

一、Java 基礎

1.JDK 和 JRE 有什麼區別?

  • JDK:  Java  Development   Kit 的簡稱,Java開發包工具,提供了Java開發環境和運行環境
  • JRE:Java Runtime  Environment的簡稱,Java運行環境,爲Java的運行提供了所需環境

具體來說JDK其實包含了JRE,同時還包含了編譯Java源碼的編輯器JavaC,還包含了很多Java程序的調試和分析工具。(這些工具可以在jdk下的bin目錄找到)。簡單來說:如果你需要運行Java程序,只需要安裝JRE就可以了,如果你需要編寫Java程序,需要安裝JDK。

2.== 和 equals 的區別是什麼?

《1.==解讀

對於基本類型和引用類型==的作用是不同的:

基本類型:比較的是值是否相同

引用類型:比較的是引用是否相同

代碼示例:

String x = "String";
String y = "String";
String z = new String("String");
System.out.println(x==y);  //true
System.out.println(x==z);  //false
System.out.println(x.equals(y));  //true
System.out.println(x.equals(z));  //true

代碼解讀:因爲x和y指向同一個引用(即在堆中的地址相同),所以==也是true,而new String() 方法則重新開闢了內存空間,所以==結果爲false,而equals比較的一直是值,所以結果都爲true。

《2.equals解讀

equals本質上就是==,只不過String和Integer等重寫了equals方法,把它變成了值比較。

例子:首先來看默認情況下equals比較一個相同值的對象,代碼如下:

/**
 * @author yuanmomo
 * @create 2019-07-08 20:59
 */
public class TestEquals1 {
    public static void main(String[] args) {
        Cat c1 = new Cat("袁默默");
        Cat c2 = new Cat("袁默默");
        System.out.println(c1.equals(c2));  //false
     }
}
class Cat {
    private String name;

    public Cat(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

輸出的結果出乎我們的意料,竟然是false?這是怎麼回事,看了equals源碼就知道了

// equals源碼
public boolean equals(Object obj) {
        return (this == obj);
    }

原來equals本質上就是==。

那問題來了,兩個相同值的String對象,爲什麼返回的是true?

String str1 = new String("袁默默");
String str2 = new String("袁默默");
System.out.println(str1.equals(str2));   //true


//String中重寫了equals
 public boolean equals(Object anObject) {
        if (this == anObject) {
            return true;
        }
        if (anObject instanceof String) {
            String anotherString = (String)anObject;
            int n = value.length;
            if (n == anotherString.value.length) {
                char v1[] = value;
                char v2[] = anotherString.value;
                int i = 0;
                while (n-- != 0) {
                    if (v1[i] != v2[i])
                        return false;
                    i++;
                }
                return true;
            }
        }
        return false;
    }
 

原來是String重寫了Object的equals方法,把引用比較改成了值比較

總結:== 對於基本類型來說是值比較,對於應用類型來說是比較的應用;而equals默認情況下是引用比較,只是很多類重新寫了equals方法,比如String、Integer等把它變成了值比較,所以一般情況下equals比較的是值是否相等。

ps:你要知道在編寫一個類的時候,可以重寫Object的類的(所有類的父類)的哪些方法?

3.兩個對象的 hashCode()相同,則 equals()也一定爲 true,對嗎?

不對,兩個對象的hashCode()相同,equals()卻不一定是true

/**
 * @author yuanmomo
 * @create 2019-07-08 20:59
 */
public class TestHashCode {
    public static void main(String[] args) {
        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
 */

看到hashCode值相等,我就有點蒙了,爲什麼會相等?又去看了一下源碼

//原來String中的hashCode值和長度有關
public int hashCode() {
        int h = hash;
        if (h == 0 && value.length > 0) {
            char val[] = value;
            
            for (int i = 0; i < value.length; i++) {
                h = 31 * h + val[i];
            }
            hash = h;
        }
        return h;
    }

代碼解讀:很顯然”通話“和”重地“的hashCode()相同,然而equals()則爲false,因爲在散列表中,hashCode()相等即兩個鍵值對的哈希值相等,然而哈希值相等,並不一定能得出鍵值對相等。

4.final 在 java 中有什麼作用?

final   adj. 最終的;決定性的;不可更改的

  • final修飾的類叫最終類,該類不能被繼承
  • final修飾的方法不能被重寫
  • final修飾的變量叫常量,常量必須初始化,初始化之後不能被修改。

5.java 中的 Math.round(-1.5) 等於多少?

等於-1;  因爲在數軸上取值,中間值(0.5)向右取整,所以正0.5是往上取值,負0.5等於直接捨棄

/**
 * @author yuanmomo
 * @create 2019-07-08 20:59
 */
public class TestMathRound {
    public static void main(String[] args) {
        System.out.println(Math.round(-1.5));
        System.out.println(Math.round(-1.51));
        System.out.println(Math.round(-1.4));
        System.out.println(Math.round(-1.6));

        System.out.println(Math.round(1.5));
        System.out.println(Math.round(1.51));
        System.out.println(Math.round(1.4));
        System.out.println(Math.round(1.6));
    }
}


/* 結果
 *-1
 *-2
 *-1
 *-2
 *2
 *2
 *1
 *2
 */

6.String 屬於基礎的數據類型嗎?

String不屬於基礎類型,基礎類型有8種:byte、boolean、char、short、int、float、long、double,而String類型屬於對象(引用類型)

7.java 中操作字符串都有哪些類?它們之間有什麼區別?

操作字符串的類有:String、StringBuffer、StringBuilder

String和StringBuffer、StringBuilder的區別在於String聲明的是不可變的對象,每次操作都會生成新的String對象,然後將指針指向新的String對象,而StringBuffer、StringBuilder可以在原有對象的基礎上進行操作,所以經常改變字符串內容的情況下最好不要使用String。

StringBuffer ----》線程安全

StringBuilder  ----》線程不安全

StringBuffer的性能高於StringBuffer。 單線程環境下推薦使用StringBuilder,多線程環境下推薦使用StringBuffer

8.String str="i"與 String str=new String(“i”)一樣嗎?

不一樣,因爲內存得分配方式不一樣。String  str = “i”的方式,Java虛擬機會將其分配到常量池中;而String  str = new String(“i”)則會被分配到堆內存中

9.如何將字符串反轉?

使用StringBuilder或者StringBuffer的reverse()方法。

package com.test.java;

/**
 * @author yuanmomo
 * @create 2019-07-08 20:59
 */
public class TestStringBufferAndStringBuilder {
    public static void main(String[] args) {
        //StringBuffer  reverse
        StringBuffer stringBuffer = new StringBuffer();
        stringBuffer.append("abcdefg");
        System.out.println(stringBuffer.reverse());  //gfedcba

        StringBuilder stringBuilder = new StringBuilder();
        stringBuilder.append("abcdefg");
        System.out.println(stringBuilder.reverse());  //gfedcba
    }
}

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

indexOf(): 返回指定字符的索引

charAt():  返回指定索引處的字符

replace():  字符串的替換

trim():  去除字符串兩端空白

split():  分割字符串,返回一個分割後的字符串數組

getBytes():  返回字符串的byte類型數組

length(): 返回字符串的長度

toLowerCase():  將字符串轉換成小寫字母

toUpperCase():  將字符串轉換成大寫字符

subString():  截取字符串

equals():  字符串比較

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

不需要,抽象類不一定非要有抽象方法

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

普通類不能包含抽象方法,抽象類可以包含抽象方法。

抽象類不能直接實例化,普通類可以直接實例化。(實例化可以通過一些方式新建一個對象,包括new)

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

不能,定義抽象類就是讓其它類繼承的,如果定義爲final該類就不能被繼承,這樣彼此就會產生矛盾,所以final不能修飾抽象類

14.接口和抽象類有什麼區別?

實現:抽象類的子類使用extends來繼承;接口必須使用implements來實現接口

構造函數:抽象類可以有構造函數;接口不能有。

實現數量:類可以實現很多接口;但是隻能繼承一個抽象類

訪問修飾符:接口中的方法默認使用public修飾;抽象類中的方法可以是任意訪問修飾符

15.java 中 IO 流分爲幾種?

按功能分: 輸入流(input)、輸出流(output)

按類型分: 字節流和字符流

字節流和字符流的區別是:字節流按8位傳輸以字節爲單位輸入數據,字節流按16位傳輸以字符爲單位輸入數據

16.BIO、NIO、AIO 有什麼區別?

BIO: Block IO 同步阻塞式IO,就是我們平時使用的傳統IO,它的特點是模式簡單使用方便,併發處理能力低

NIO: New  IO 同步非阻塞IO, 是傳統IO的升級,客戶端和服務端通過Channel(通道)通訊,實現了多路複用

AIO:  Asynchronous  IO 是NIO 的升級,也叫NIO2,實現了異步非阻塞IO,異步IO的操作基於事件和回調機制。

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

Files.exists():  檢測文件路徑是否存在

Files.createFile(): 創建文件

Files.createDirectory(): 創建文件夾

Files.delete():  刪除一個文件或目錄

Files.copy(): 複製文件

Files.move():  移動文件

Files.size():  查看文件個數

Files.read(): 讀取文件

Files.write(): 寫入文件

 

二、容器

18.java 容器都有哪些?

 

19.Collection 和 Collections 有什麼區別?

Collection是一個集合接口,它提供了對象集合對象進行基本的通用接口方法,所有集合都是它的子類,比如List、Set等。

Collections是一個包裝類,包含了很多靜態方法,不能被實例化,就像一個工具類,比如提供的排序方法:Collections.sort(list)

20.List、Set、Map 之間的區別是什麼?

21.HashMap 和 Hashtable 有什麼區別?

存儲:HashMap運行key和value爲null,而Hashtable不允許。

線程安全:Hashtable是線程安全的,而HashMap是非線程安全的。

推薦使用:在Hashtable的類註釋中可以看到,Hashtable是保留類不建議使用,推薦在單線程環境下使用HashMap.如果需要多線程則使用ConcurrentHashMap(分段的)

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

對於在Map中插入、刪除、定位一個元素這類操作,HashMap是最好的選擇,因爲相對而言HashMap的插入會更快,但如果你要對一個key集合進行有序的遍歷,那TreeMap是更好的選擇。

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

24.說一下 HashSet 的實現原理?

25.ArrayList 和 LinkedList 的區別是什麼?

26.如何實現數組和 List 之間的轉換?

27.ArrayList 和 Vector 的區別是什麼?

28.Array 和 ArrayList 有何區別?

29.在 Queue 中 poll()和 remove()有什麼區別?

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

31.迭代器 Iterator 是什麼?

32.Iterator 怎麼使用?有什麼特點?

33.Iterator 和 ListIterator 有什麼區別?

34.怎麼確保一個集合不能被修改?

三、多線程

35.並行和併發有什麼區別?

36.線程和進程的區別?

37.守護線程是什麼?

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

39.說一下 runnable 和 callable 有什麼區別?

40.線程有哪些狀態?

41.sleep() 和 wait() 有什麼區別?

42.notify()和 notifyAll()有什麼區別?

43.線程的 run()和 start()有什麼區別?

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

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

46.線程池中 submit()和 execute()方法有什麼區別?

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

48.多線程鎖的升級原理是什麼?

49.什麼是死鎖?

50.怎麼防止死鎖?

51.ThreadLocal 是什麼?有哪些使用場景?

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

53.synchronized 和 volatile 的區別是什麼?

54.synchronized 和 Lock 有什麼區別?

55.synchronized 和 ReentrantLock 區別是什麼?

56.說一下 atomic 的原理?

四、反射

57.什麼是反射?

58.什麼是 java 序列化?什麼情況下需要序列化?

59.動態代理是什麼?有哪些應用?

60.怎麼實現動態代理?

五、對象拷貝

61.爲什麼要使用克隆?

62.如何實現對象克隆?

63.深拷貝和淺拷貝區別是什麼?

六、Java Web

64.jsp 和 servlet 有什麼區別?

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

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

67.session 和 cookie 有什麼區別?

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

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

70.spring mvc 和 struts 的區別是什麼?

71.如何避免 sql 注入?

72.什麼是 XSS 攻擊,如何避免?

73.什麼是 CSRF 攻擊,如何避免?

七、異常

74.throw 和 throws 的區別?

75.final、finally、finalize 有什麼區別?

76.try-catch-finally 中哪個部分可以省略?

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

78.常見的異常類有哪些?

八、網絡

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

80.forward 和 redirect 的區別?

81.簡述 tcp 和 udp的區別?

82.tcp 爲什麼要三次握手,兩次不行嗎?爲什麼?

83.說一下 tcp 粘包是怎麼產生的?

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

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

86.如何實現跨域?

87.說一下 JSONP 實現原理?

九、設計模式

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

89.簡單工廠和抽象工廠有什麼區別?

十、Spring/Spring MVC

90.爲什麼要使用 spring?

91.解釋一下什麼是 aop?

92.解釋一下什麼是 ioc?

93.spring 有哪些主要模塊?

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

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

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

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

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

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

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

101.spring mvc 有哪些組件?

102.@RequestMapping 的作用是什麼?

103.@Autowired 的作用是什麼?

十一、Spring Boot/Spring Cloud

104.什麼是 spring boot?

105.爲什麼要用 spring boot?

106.spring boot 核心配置文件是什麼?

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

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

109.jpa 和 hibernate 有什麼區別?

110.什麼是 spring cloud?

111.spring cloud 斷路器的作用是什麼?

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

十二、Hibernate

113.爲什麼要使用 hibernate?

114.什麼是 ORM 框架?

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

116.hibernate 有幾種查詢方式?

117.hibernate 實體類可以被定義爲 final 嗎?

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

119.hibernate 是如何工作的?

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

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

122.hibernate 對象有哪些狀態?

123.在 hibernate 中 getCurrentSession 和 openSession 的區別是什麼?

124.hibernate 實體類必須要有無參構造函數嗎?爲什麼?

十三、Mybatis

125.mybatis 中 #{}和 ${}的區別是什麼?

126.mybatis 有幾種分頁方式?

127.RowBounds 是一次性查詢全部結果嗎?爲什麼?

128.mybatis 邏輯分頁和物理分頁的區別是什麼?

129.mybatis 是否支持延遲加載?延遲加載的原理是什麼?

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

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

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

133.mybatis 分頁插件的實現原理是什麼?

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

十四、RabbitMQ

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

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

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

138.rabbitmq 中 vhost 的作用是什麼?

139.rabbitmq 的消息是怎麼發送的?

140.rabbitmq 怎麼保證消息的穩定性?

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

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

143.rabbitmq 持久化有什麼缺點?

144.rabbitmq 有幾種廣播類型?

145.rabbitmq 怎麼實現延遲消息隊列?

146.rabbitmq 集羣有什麼用?

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

148.rabbitmq 集羣搭建需要注意哪些問題?

149.rabbitmq 每個節點是其他節點的完整拷貝嗎?爲什麼?

150.rabbitmq 集羣中唯一一個磁盤節點崩潰了會發生什麼情況?

151.rabbitmq 對集羣節點停止順序有要求嗎?

十五、Kafka

152.kafka 可以脫離 zookeeper 單獨使用嗎?爲什麼?

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

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

155.什麼情況會導致 kafka 運行變慢?

156.使用 kafka 集羣需要注意什麼?

十六、Zookeeper

157.zookeeper 是什麼?

158.zookeeper 都有哪些功能?

159.zookeeper 有幾種部署模式?

160.zookeeper 怎麼保證主從節點的狀態同步?

161.集羣中爲什麼要有主節點?

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

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

十七、MySql

164.數據庫的三範式是什麼?

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

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

167.說一下 ACID 是什麼?

168.char 和 varchar 的區別是什麼?

169.float 和 double 的區別是什麼?

170.mysql 的內連接、左連接、右連接有什麼區別?

171.mysql 索引是怎麼實現的?

172.怎麼驗證 mysql 的索引是否滿足需求?

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

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

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

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

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

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

十八、Redis

179.redis 是什麼?都有哪些使用場景?

180.redis 有哪些功能?

181.redis 和 memecache 有什麼區別?

182.redis 爲什麼是單線程的?

183.什麼是緩存穿透?怎麼解決?

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

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

186.jedis 和 redisson 有哪些區別?

187.怎麼保證緩存和數據庫數據的一致性?

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

189.redis 怎麼實現分佈式鎖?

190.redis 分佈式鎖有什麼缺陷?

191.redis 如何做內存優化?

192.redis 淘汰策略有哪些?

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

十九、JVM

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

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

196.說一下堆棧的區別?

197.隊列和棧是什麼?有什麼區別?

198.什麼是雙親委派模型?

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

200.怎麼判斷對象是否可以被回收?

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

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

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

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

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

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

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

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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章