Java程序員從阿里、京東、美團面試回來,這些面試題你會嗎?
最近有很多朋友去目前主流的大型互聯網公司面試(阿里巴巴、京東、美團、),面試回來之後會發給我一些面試題。有些朋友輕鬆過關拿到offer,但是有一些是來詢問我答案的。
其實本來真的沒打算寫這篇文章,主要是自己得記憶力不是很好,不像一些記憶力強的人,面試完以後,幾乎能把自己和面試官的對話都給記下來。自己當初面試完以後,除了記住一些聊過的知識點以外,具體的內容基本上忘得一乾二淨,所以寫這篇文章其實是很有難度的。
但是,最近問我的人實在是太多了,爲了避免重複回答,給自己省點力氣,乾脆就在這裏統一回復了。
說實話,我只能隱約想起高併發、JVM、分佈式跟TCP/IP協議這些個關鍵字,具體的問題真的是幾乎都沒記住。而且就算我記住了,也告訴你了,你也背會了,但我覺得,在面試中,你被問到一模一樣問題的可能性依然很小。
甚至就算你運氣好被問到了,你也照着背下來了,也不一定就能對你的面試起到正面的作用,因爲面試官萬一多問一句,你可能就露餡了,那還不如干脆點說不會更好。 在此給大家講一下大型互聯網企業面試題。
先來看下自己記錄的面試材料:
一、阿里巴巴面試
第一個:阿里面試都問什麼? :(55分鐘)
1、開發中Java用了比較多的數據結構有哪些?
2、談談你對HashMap的理解,底層原理的基本實現,HashMap怎麼解決碰撞問題的?
這些數據結構中是線程安全的嗎?假如你回答HashMap是線程安全的,接着問你有沒有線程安全的map,接下來問了conurren包。
3、對JVM熟不熟悉?簡單說說類加載過程,裏面執行的哪些操作?問了GC和內存管理,平時在tomect裏面有沒有進行過相關的配置。
4、然後問了http協議,get和post的基本區別,接着tcp/ip協議,三次握手,窗口滑動機制。
5、開發中用了那些數據庫?回答mysql,儲存引擎有哪些?然後問了我悲觀鎖和樂觀鎖問題使用場景、分佈式集羣實現的原理。
6、然後問了我springmvc和mybatis的工作原理,有沒有看過底層源碼?
二、京東金融面試
1、Dubbo超時重試;Dubbo超時時間設置
2、如何保障請求執行順序
3、分佈式事物與分佈式鎖(扣款不要出現負數)
4、分佈式session設置
5、執行某操作,前50次成功,第51次失敗a全部回滾b前50次提交第51次拋異常,ab場景分別如何設置Spring(傳播性)
6、Zookeeper有哪些用
7、JVM內存模型
8、數據庫垂直和水平拆分
9、MyBatis如何分頁;如何設置緩存;MySQL分頁
10、熟悉IO麼?與NIO的區別,阻塞與非阻塞的區別
11、分佈式session一致性
12、分佈式接口的冪等性設計「不能重複扣款」
三、美團面試
1、最近做的比較熟悉的項目是哪個?畫一下項目技術架構圖。
2、JVM老年代和新生代的比例?
3、YGC和FGC發生的具體場景。
4、jstack,jmap,jutil分別的意義?如何線上排查JVM的相關問題?
5、線程池的構造類的方法的5個參數的具體意義?
6、單機上一個線程池正在處理服務如果忽然斷電該怎麼辦?(正在處 理和阻塞隊列裏的請求怎麼處理)?
7、使用無界阻塞隊列會出現什麼問題?
8、接口如何處理重複請求?
9、具體處理方案是什麼?
10、如何保證共享變量修改時的原子性?
11、設計一個對外服務的接口實現類,在1,2,3這三個主機(對應不同IP)上實現負載均衡和順序輪詢機制(考慮併發)
以上是對大型互聯網名企面試題收集分享,分享給大家,希望大家可以瞭解什麼是大型互聯網名企面試題。