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

1、基礎與框架

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如何管理事務的

2、多線程

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.若是讓你實現一個併發安全的鏈表,你會怎麼作

3、JVM相關

1.jvm中一次完整的GC流程(從ygc到fgc)是怎樣的,重點講講對象如何晉升到老年代,幾種主要的jvm參數等
2.你知道哪幾種垃圾收集器,各自的優缺點,重點講下cms
3.當出現了內存溢出,你怎麼排錯
4.JVM內存模型的相關知識瞭解多少
5.簡單說說你瞭解的類加載器
6.JAVA的反射機制

4、網絡

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.一個在線文檔系統,文檔能夠被編輯,如何防止多人同時對同一份文檔進行編輯更新

5、算法

一、10億個數字裏裏面找最小的10個
二、有1億個數字,其中有2個是重複的,快速找到它,時間和空間要最優
三、2億個隨機生成的無序整數,找出中間大小的值
四、遍歷二叉樹

6、數據庫

1.數據庫隔離級別有哪些,各自的含義是什麼,MYsql默認的隔離級別是是什麼,各個存儲引擎優缺點
2.高併發下,如何作到安全的修改同一行數據,樂觀鎖和悲觀鎖是什麼,INNODB的行級鎖有哪2種,解釋其含義
3.SQL優化的通常步驟是什麼,怎麼看執行計劃,如何理解其中各個字段的含義,索引的原理?
4.數據庫會死鎖嗎,舉一個死鎖的例子,mysql怎麼解決死鎖
5.MYsql的索引實現方式
6.彙集索引和非彙集索引的區別
7.數據庫中 BTREE和B+tree區別

7、最後

歡迎你們關注個人公衆號【程序員追風】,文章都會在裏面更新,整理的資料也會放在裏面。
相關文章
相關標籤/搜索