最近面試了阿里、京東、美團、滴滴等大型互聯網公司,最終收到了美團offer,此次面試事後,我把面試過的公司的面試題作了一個整理。這篇文章是我憑回憶記錄的,面試題沒有順序,不分前後,接下來公佈我去阿里、京東、美團等一線互聯網公司的面試題:
mysql
一、開發中Java用得比較多的數據結構有哪些?程序員
二、談談你對HashMap的理解,底層原理的基本實現,HashMap怎麼解決碰撞問題的?面試
這些數據結構中是線程安全的嗎?假如你回答HashMap是線程安全的,接着問有沒有線程安全的map,接下來問conurren包。spring
三、對JVM熟不熟悉?簡單說說類加載過程,裏面執行的哪些操做?問了GC和內存管理,平時在tomect裏面有沒有進行過相關的配置。sql
四、說一下http協議、get和post的基本區別,接着問tcp/ip協議,三次握手,窗口滑動機制。數據庫
五、開發中用了哪些數據庫?回答mysql;儲存引擎有哪些?而後問了我悲觀鎖和樂觀鎖問題使用場景、分佈式集羣實現的原理。緩存
六、springmvc和mybatis的工做原理,有沒有看過底層源碼?安全
一、Dubbo超時重試;Dubbo超時時間設置session
二、如何保障請求執行順序數據結構
三、分佈式事物與分佈式鎖(扣款不要出現負數)
四、分佈式session設置
五、執行某操做,前50次成功,第51次失敗a所有回滾b前50次提交第51次拋異常,ab場景分別如何設置Spring(傳播性)
六、Zookeeper有哪些用
七、JVM內存模型
八、數據庫垂直和水平拆分
九、MyBatis如何分頁;如何設置緩存;MySQL分頁。
十、熟悉IO麼?與NIO的區別,阻塞與非阻塞的區別。
十一、分佈式session一致性
十二、分佈式接口的冪等性設計「不能重複扣款」
一、最近作的比較熟悉的項目是哪一個?畫一下項目技術架構圖。
二、JVM老年代和新生代的比例?
三、YGC和FGC發生的具體場景
四、jstack,jmap,jutil分別的意義?如何線上排查JVM的相關問題?
五、線程池的構造類的方法的5個參數的具體意義?
六、單機上一個線程池正在處理服務若是突然斷電該怎麼辦?(正在處理和阻塞隊列裏的請求怎麼處理?)
七、使用無界阻塞隊列會出現什麼問題?
八、接口如何處理重複請求?
九、具體處理方案是什麼?
十、如何保證共享變量修改時的原子性?
十一、設計一個對外服務的接口實現類,在1,2,3這三個主機(對應不一樣IP)上實現負載均衡和順序輪詢機制(考慮併發)
一、自我介紹;技術特色
二、興趣是什麼;優點是什麼
三、jvm、jre以及jdk三者之間的關係?
四、Dubbo的底層原理,Zookeeper是什麼
五、cincurrentMap的機制;TreeMap;Volatil關鍵字
六、快速排序;廣度優先搜索(隊列實現)
七、緩存的雪崩以及穿透的理解?
八、HashMap的key能夠重複嗎?
九、synchronized和lock的區別?
10.開發一個大型網站你會考慮哪些問題?
以上就是所有的面試題目,針對以上知識點,結合當前互聯網公司的技術需求及主流技術,我整理了一套系統的架構技術體系。很多公司都很重視高併發高可用的技術,特別是一線互聯網公司,分佈式、JVM、spring源碼分析、微服務等知識點已是面試的必考題。這些東西可能大家平時在工做中接觸過,可是缺乏的全面系統的學習,但願對正在面試的朋友或是遭遇技術瓶頸的程序員們提供一點思路。
以上視頻資料是我結合本身和身邊朋友的面試經歷而整理的,但願對面試的朋友或者在找工做的程序員們有所幫助。你們能夠經過掃碼進羣下載資料,對技術感興趣的朋友也能夠來Java資源分享羣:(854601507),資料會不按期更新,羣裏有一些阿里大牛,也有一線互聯網的資深HR,點擊下方的閱讀原文就能夠進羣啦!