前言
我相信大多 Java 開發的程式員或多或少經歷過阿里的面試,也清楚阿里 Java面試是有一定難度的,作者經歷過多次阿里的面試,有滿意的也有備受打擊的,因此呢作者想把自己這么多次面試經歷來個匯總,正值金九銀十之際,希望對大家有所幫助,
另外本人整理收藏了20年多家公司面試知識點整理 ,以及各種Java核心知識點免費分享給大家,我認為對面試來說是非常有用的,有需要的朋友可以可以點擊這里!暗號博客園自行領取

阿里面試題
由于時間關系答案我就不寫了(主要是懶),都總結成筆記了
在阿里面試還是很舒服的,面試官覺得有難度的話會適可而止,不會讓你覺得不會而感到尷尬,一面的知識也不是很難
一面
1.HashMap的資料結構——引出Java7跟Java8的區別
2.在什么情況下會做一個鏈表到紅黑樹的轉換
3.除了資料結構之外,Java8跟Java7在HashMap上還有什么不同
4.擴容的程序,在什么情況下會擴容
5.擴容機制中的capacity初始值為什么是16,可不可以自定義成15,為什么一定要是2的指數次方
6.簡單介紹一下hash演算法,它的核心性能,或者說判斷一個hash演算法好壞的指標是什么,indexFor()函式的實作
7.HashMap為了解決什么問題?——引出哈希碰撞
8.介紹ConcurrentHashMap的資料結構
9.ConcurrentHashMap可以支持多少并發執行緒
10.ConcurrentHashMap屬于JOC下的一個類,對JOC這個包的了解
11.是否用過synchronized,之前是否碰到過并發問題,怎么處理
12.在Java技術堆疊方面,有沒有比較擅長或者深入了解的點,是否從原始碼上看過一些東西
13. Netty原理介紹下,
14. 了解過NIO,BIO,AIO么?介紹下異同,代碼中如何使用?
15. 分布式鎖用過么?用什么函式?什么使用場景?
16. 能介紹下垃圾回識訓制么?
17. redis的資料結構介紹下,專案中用過哪些?什么場景
18 冪等性是什么?如何保障?
19. 交易系統中的資料一致性咋保障?
資料庫
1.對MySQL了解多少——引出必問知識點(劃重點!!!事務和索引)
2.MySQL用的隔離級別是什么,這個隔離級別下會出現什么問題——引出資料庫的并發問題
3.MySQL使用這種隔離級別時,是如何解決幻讀問題的(引申,理解其他并發問題的解決原理)
4.MySQL的調優機制,主要是哪些方面的調優——引出索引
5.在MySQL的InnoDB這個存盤引擎下,聚集索引(或者聚簇索引)和非聚集索引這兩個概念
6.MySQL中的索引是用什么資料結構存盤的——此處應該引出B+樹
7.為什么通過索引查詢速度會更快一些——此處應該引出二叉樹演算法
二面
自我介紹
專案中的mongoDB使用場景是啥?如何部署的?怎么保證高可用性?
JVM的記憶體結構能介紹下么?
CMS和G1的優缺點?什么時候發生FULL GC?什么時候stop the world!
什么樣的物件能當根節點?
一個類,兩個函式,一讀一寫,寫函式加synchronized,讀函式還用加么?voliate關鍵字啥作用?
資料庫設計時,主鍵咋設?自增好還是非自增好?為啥?
mysql的鎖型別介紹下
線上CPU 100%了怎么查?
寫個演算法,給一個數字,一個單調陣列中,方法回傳陣列中第一個大于給定數字的下標,如果沒有,回傳-1,
三面
說實話第三輪就是比較深度的問題了,都是結合業務談談自己的程式思想,如果沒有一定的技術和開發經驗這個是回答不完整的,本人就是倒在了這一關,
如何實作一個高效的單向鏈表逆序輸出?
已知sqrt(2)約等于1.414,要求不用數學庫,求sqrt(2)精確到小數點后10位
給定一個二叉搜索樹(BST),找到樹中第 K 小的節點
LRU快取機制
關于epoll和select的區別,以下哪些說法是正確的
從innodb的索引結構分析,為什么索引的 key 長度不能太長
給定一個鏈表,洗掉鏈表的倒數第N個節點,并且回傳鏈表的頭結點
如果讓你設計一個通用的、支持各種資料庫秒級備份和恢復的系統,你會如何設計
如果讓你來設計一個支持資料庫、NOSQL 和大資料之間資料實時流動的資料流及處理的系統,你會考慮哪些問題?如何設計?
給定一個整數陣列和一個整數,回傳兩個陣列的索引,這兩個索引指向的數字的加和等于指定的整數,需要最優的演算法,分析演算法的空間和時間復雜度
假如給你一個新產品,你將從哪些方面來保障它的質量?
請評估一下程式的執行結果?
騰訊面試題
Java基礎
1.JAVA中的幾種基本資料型別是什么,各自占用多少位元組,
2.String類能被繼承嗎,為什么,
3.String,Stringbuffer,StringBuilder的區別,
4.ArrayList和LinkedList有什么區別,
5.講講類的實體化順序,比如父類靜態資料,建構式,欄位,子類靜態資料,建構式,欄位,當new的時候,他們的執行順序,
6.用過哪些Map類,都有什么區別,HashMap是執行緒安全的嗎,并發下使用的Map是什么,他們內部原理分別是什么,比如存盤方式,hashcode,擴容,默認容量等,
7.JAVA8的ConcurrentHashMap為什么放棄了分段鎖,有什么問題嗎,如果你來設計,你如何設計,
8.有沒有有順序的Map實作類,如果有,他們是怎么保證有序的,
9.抽象類和介面的區別,類可以繼承多個類么,介面可以繼承多個介面么,類可以實作多個介面么,
10.繼承和聚合的區別在哪,
11.IO模型有哪些,講講你理解的nio ,他和bio,aio的區別是啥,談談reactor模型,
12.反射的原理,反射創建類實體的三種方式是什么,
13.反射中,Class.forName和ClassLoader區別 ,
14.描述動態代理的幾種實作方式,分別說出相應的優缺點,
15.動態代理與cglib實作的區別,
16.為什么CGlib方式可以對介面實作代理,
17.final的用途,
18.寫出三種單例模式實作 ,
19.Java中的HashSet內部是如何作業的,
20.什么是序列化,怎么序列化,為什么序列化,反序列化會遇到什么問題,如何解決,
JVM
21.什么情況下會發生堆疊記憶體溢位,
22.JVM的記憶體結構,Eden和Survivor比例,
23.JVM記憶體為什么要分成新生代,老年代,持久代,新生代中為什么要分為Eden和Survivor,
24.JVM中一次完整的GC流程是怎樣的,物件如何晉升到老年代,說說你知道的幾種主要的JVM引數,
25.你知道哪幾種垃圾收集器,各自的優缺點,重點講下cms和G1,包括原理,流程,優缺點,
26.垃圾回收演算法的實作原理,
27.當出現了記憶體溢位,你怎么排錯,
28.簡單說說你了解的類加載器,可以打破雙親委派么,怎么打破,
29.g1和cms區別,吞吐量優先和回應優先的垃圾收集器選擇,
30.怎么打出執行緒堆疊資訊,
開源框架
31.簡單講講tomcat結構,以及其類加載器流程,執行緒模型等,
32.tomcat如何調優,涉及哪些引數 ,
33.講講Spring加載流程,
34.Spring AOP的實作原理,
35.講講Spring事務的傳播屬性,
36.Spring如何管理事務的,
37.說說你對Spring的理解,非單例注入的原理?它的生命周期?回圈注入的原理,aop的實作原理,說說aop中的幾個術語,它們是怎么相互作業的,
38.Springmvc 中DispatcherServlet初始化程序,
39.netty的執行緒模型,netty如何基于reactor模型上實作的,
40.netty的通訊協議是什么樣的,
41.springmvc用到的注解,作用是什么,原理,
42.springboot啟動機制
百度面試題
1、自我介紹以及專案介紹
2、spring-cloud是否了解,spring-boot是了解,講一講bean的生命周期
3、hashmap-1.8后的改進,hashmap為什么是執行緒不安全的
4、如何做到執行緒安全,concurrenthashmap是怎么實作的
5、用到哪些的設計模式
6、ThreadLocal用過嗎
7、類的加載機制
8、JVM-記憶體模型
9、垃圾回收
10、redis原始碼有讀過嗎
11. 介紹你做的專案和其中的難點?
12.反射的作用是什么?
13. 資料倉庫,多執行緒和并發工具等?
14. 私有云,docker和k8s等?
15. 了解哪些中間件,dubbo,rocketmq,mycat等?
16. dubbo中的rpc如何實作?
17. 自己實作rpc應該怎么做?
18. dubbo的服務注冊與發現?
19.給你一個有序整數陣列,陣列中的數可以是正數、負數、零,請實作一個函式,這個函式回傳一個整數:回傳這個陣列所有數的平方值中有多少種不同的取值,
總結
互聯網大廠比較喜歡的人才特點:對技術有熱情,強硬的技識訓礎實力;主動,善于團隊協作,善于總結思考,無論是哪家公司,都很重視高并發高可用技術,重視基礎,所以千萬別小看任何知識,面試是一個雙向選擇的程序,不要抱著畏懼的心態去面試,不利于自己的發揮,同時看中的應該不止薪資,還要看你是不是真的喜歡這家公司,是不是能真的得到鍛煉,其實我寫了這么多,只是我自己的總結,并不一定適用于所有人,相信經過一些面試,大家都會有這些感觸,
最后
本人還整理收藏了20年多家公司面試知識點以及各種技術點整理 下面有部分截圖,需要的朋友可以點擊這里!暗號博客園自行領取

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/238948.html
標籤:其他
