70道阿里百度高頻Java面試題(框架+JVM+多線程+算法+數據庫)

基礎與框架

1.String類能被繼承嗎,爲什麼

2.String,Stringbuffer,StringBuilder的區別?

3.ArrayList和LinkedList有什麼區別

4.類的實例化順序,比如父類靜態數據,構造函數,字段,子類靜態數據,構造函數,字段,他們的執行順序

5.用過哪些Map,都有什麼區別,HashMap是線程安全的嗎,併發下使用的Map是什麼,他們內部原理分別是什麼,比如hashcode,擴容等

6.HashMap爲什麼get和set那麼快,concurrentHashMap爲什麼能提高併發

7.抽象類和接口的區別,類可以繼承多個類麼,接口可以繼承多個接口麼,類可以實現多個接口麼

8.什麼情況下會發生棧內存溢出

9.什麼是nio,原理

10.反射中,Class.forName和ClassLoader區別

11.tomcat結構,類加載器流程

12.講講Spring事務的傳播屬性,AOP原理,動態代理與cglib實現的區別,AOP有哪幾種實現方式

13.Spring的beanFactory和factoryBean的區別

14.Spring加載流程

15.Spring如何管理事務的

多線程

1.線城池的最大線程數目根據什麼確定

2.多線程的幾種實現方式,什麼是線程安全,什麼是重排序

3.volatile的原理,作用,能代替鎖麼

4.sleep和wait的區別,以及wait的實現原理

5.Lock與synchronized 的區別,synchronized 的原理,什麼是自旋鎖,偏向鎖,輕量級鎖,什麼叫可重入鎖,什麼叫公平鎖和非公平鎖

6.用過哪些原子類,他們的參數以及原理是什麼

7.用過哪些線程池,他們的原理簡單概括下,構造函數的各個參數的含義,比如coreSize,maxsize等

8.有一個第三方接口,有很多個線程去調用獲取數據,現在規定每秒鐘最多有10個線程同時調用它,如何做到。

9.spring的controller是單例還是多例,怎麼保證併發的安全

10.用三個線程按順序循環打印abc三個字母,比如abcabcabc

11.ThreadLocal用過麼,原理是什麼,用的時候要注意什麼

12.如果讓你實現一個併發安全的鏈表,你會怎麼做

JVM相關

1.jvm中一次完整的GC流程(從ygc到fgc)是怎樣的,重點講講對象如何晉升到老年代,幾種主要的jvm參數等

2.你知道哪幾種垃圾收集器,各自的優缺點,重點講下cms

3.當出現了內存溢出,你怎麼排錯

4.JVM內存模型的相關知識瞭解多少

5.簡單說說你瞭解的類加載器

6.JAVA的反射機制

網絡

1.http1.0和http1.1有什麼區別

2.TCP三次握手和四次揮手的流程,爲什麼斷開連接要4次,如果握手只有兩次,會出現什麼

3.TIME_WAIT和CLOSE_WAIT的區別

4.說說你知道的幾種HTTP響應碼

5.當你用瀏覽器打開一個鏈接的時候,計算機做了哪些工作步驟

6.Linux下IO模型有幾種,各自的含義是什麼

7.TCP/IP如何保證可靠性,數據包有哪些數據組成

8.架構設計與分佈式:

9.tomcat如何調優,各種參數的意義

10.常見的緩存策略有哪些,你們項目中用到了什麼緩存系統,如何設計的,Redis的使用要注意什麼,持久化方式,內存設置,集羣,淘汰策略等

11.如何防止緩存雪崩

12.用java自己實現一個LRU

13.分佈式集羣下如何做到唯一序列號

14.設計一個秒殺系統,30分鐘沒付款就自動關閉交易

15.如何做一個分佈式鎖

16.用過哪些MQ,怎麼用的,和其他mq比較有什麼優缺點,MQ的連接是線程安全的嗎

17.MQ系統的數據如何保證不丟失

18.分佈式事務的原理,如何使用分佈式事務

19.什麼是一致性hash

20.什麼是restful,講講你理解的restful

21.如何設計建立和保持100w的長連接?

22.解釋什麼是MESI協議(緩存一致性)

23.說說你知道的幾種HASH算法,簡單的也可以

24.什麼是paxos算法

25.redis和memcached 的內存管理的區別

26.一個在線文檔系統,文檔可以被編輯,如何防止多人同時對同一份文檔進行編輯更新

算法

1、10億個數字裏裏面找最小的10個

2、有1億個數字,其中有2個是重複的,快速找到它,時間和空間要最優

3、2億個隨機生成的無序整數,找出中間大小的值

4、遍歷二叉樹

數據庫

1.數據庫隔離級別有哪些,各自的含義是什麼,MYsql默認的隔離級別是是什麼,各個存儲引擎優缺點

2.高併發下,如何做到安全的修改同一行數據,樂觀鎖和悲觀鎖是什麼,INNODB的行級鎖有哪2種,解釋其含義

3.SQL優化的一般步驟是什麼,怎麼看執行計劃,如何理解其中各個字段的含義,索引的原理?

4.數據庫會死鎖嗎,舉一個死鎖的例子,mysql怎麼解決死鎖

5.MYsql的索引實現方式

6.聚集索引和非聚集索引的區別

7.數據庫中 BTREE和B+tree區別

最後
歡迎大家一起交流,喜歡文章記得關注我點個贊喲,感謝支持!

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