金三銀四跳槽季即將到來,作為 Java 開發者你開始刷面試題了嗎?別急,小編整理了阿裡技術面試題,看這一文就夠了! 阿裡面試題目目錄 技術一面(基礎面試題目) 技術二面(技術深度、技術原理) 項目實戰(項目模擬面試) JAVA開發技術常問的問題 阿裡必會知識 阿裡面試範疇 面試總結 文章福利(答案獲 ...
金三銀四跳槽季即將到來,作為 Java 開發者你開始刷面試題了嗎?別急,小編整理了阿裡技術面試題,看這一文就夠了!
阿裡面試題目目錄
- 技術一面(基礎面試題目)
- 技術二面(技術深度、技術原理)
- 項目實戰(項目模擬面試)
- JAVA開發技術常問的問題
- 阿裡必會知識
- 阿裡面試範疇
- 面試總結
- 文章福利(答案獲取)
一:阿裡技術一面(基礎掌握牢固)
- 常用的異常類型?
- session
- java鎖
- gc原理
- hashmap
- listlink arraylist 區別
- aop 原理
- 多線程
- kafka 原理和容錯
- spark hadoop 原理
- redis 同步機制
- classLoader 機制
- Http 協議
- cookie的限制
- 如何設計一個分步式登錄系統?
- Spring載入過程?
- 自己有沒有寫過類似Spring這樣的AOP事務?
- spring的載入過程?
- atomic 與 volatile的區別?
- Thread的 notify()給notifyAll()的區別?
- notifiy()是喚醒的那一個線程?
- Thread.sleep()喚醒以後是否需要重新競爭?
- 單例有多少種寫法? 有什麼區別? 你常用哪一種單例,為什麼用這種?
- 問一個Thread.join()相關的問題?
- 寫一個JAVA死鎖的列子?
- 如何解決死鎖?
- GC回收演算法,及實現原理?
- HashMap數據存儲結構? key重覆了怎麼辦? 是如何解決的?
- Spring AOP的實現原理,底層用什麼實現的?
阿裡技術二面(技術原理、個人擅長的項目)
重點是面試技術原理,以及對技術的熱情和專研程度:
- Java的高級知識
- 開源框架的原理
- JVM
- 多線程
- 高併發
- 中間件
- 之前項目經歷,運用的技術,遇到的問題,如何解決,個人有什麼收穫和成長;
- 對於技術的熱情(平時是否看些技術書籍,逛論壇,寫博客,寫源代碼或程式等)
JAVA開發技術面試可能問到的問題?
- 我們主要考核的是網路nio 分散式資料庫高併發大數據
- 自定義表格的實現?
- 動態表單設計?
- in-jvm(必考)以及jmm緩存模型如何調優?
- 常用的RPC框架
- nio和io
- 併發編程,設計模式
- 地圖組件?
- hashmap有什麼漏洞會導致他變慢?
- 如何給hashmap的key對象設計他的hashcode?
- 泛型通配符?在什麼情況下使用?
- 後端方面:redis?分散式框架dubbo(阿裡巴巴開源框架)?設計模式?
- 場景式的問題:秒殺,能列出常見的排隊、驗證碼、庫存扣減方式對系統高併發的影響?
- 能根據實際的需要構建緩存結構提高提高網站的訪問速度,熟練使用ehcache、oscache,瞭解memcache。
- 瞭解基於dns輪詢的負載均衡,熟練配置web伺服器實現負載均衡,程式級能綜合使用基於hash或取模等手段實現軟負載。
- 熟悉分散式資料庫設計和優化技術,熟練使用mysql、oracle、SqlServer等主流資料庫,熟悉hadoop hbase mangodb redis ehcache、oscache memcache。對於大數據量的資料庫處理採用分表分庫、資料庫讀寫分離、建立緩存等手段優化性能。
- 熟練掌握lucene,能基於lucene開發大型的搜索引擎,並能用lucene來改善和優化資料庫的like查詢。
項目部分
- 緩存的使用,如果現在需要實現一個簡單的緩存,供搜索框中的ajax非同步請求調用,使用什麼結構?
- 記憶體中的緩存不能一直存在,用什麼演算法定期將搜索權重較低的entry去掉?
- TCP如何保證安全性
- 紅黑樹的問題,B+數
- JDK1.8中對HashMap的增強,如果一個桶上的節點數量過多,鏈表+數組的結構就會轉換為紅黑樹。
- 項目中使用的單機伺服器,如果將它部署成分散式伺服器?
- MySQL的常見優化方式、定為慢查詢
- 手寫一個線程安全的單例模式
進阿裡必會知識:
- 演算法和數據結構數組、鏈表、二叉樹、隊列、棧的各種操作(性能,場景)
- 二分查找和各種變種的二分查找
- 各類排序演算法以及複雜度分析(快排、歸併、堆)
- 各類演算法題(手寫)
- 理解並可以分析時間和空間複雜度。
- 動態規劃(筆試回回有。。)、貪心。
- 紅黑樹、AVL樹、Hash樹、Tire樹、B樹、B+樹。
- 圖演算法(比較少,也就兩個最短路徑演算法理解吧)
- 電腦網路OSI7層模型(TCP4層)每層的協議
- get/post 以及冪等性
- http 協議頭相關
- 網路攻擊(CSRF、XSS)
- TCP/IP三次握手、四次揮手
- TCP與UDP比較
- DDos攻擊
- (B)IO/NIO/AIO三者原理,各個語言是怎麼實現的
- Netty
- Linux內核select poll epoll
- 資料庫(最多的還是mysql,Nosql有redis)索引(包括分類及優化方式,失效條件,底層結構)
- sql語法(join,union,子查詢,having,group by)
- 引擎對比(InnoDB,MyISAM)
- 資料庫的鎖(行鎖,表鎖,頁級鎖,意向鎖,讀鎖,寫鎖,悲觀鎖,樂觀鎖,以及加鎖的select sql方式)
- 隔離級別,依次解決的問題(臟讀、不可重覆讀、幻讀)
- 事務的ACID
- B樹、B+樹
- 優化(explain,慢查詢,show profile)
- 資料庫的範式
- 分庫分表,主從複製,讀寫分離。
- Nosql相關(redis和memcached區別之類的,如果你熟悉redis,redis還有一堆要問的)
- 操作系統:進程通信IPC(幾種方式),與線程區別
- OS的幾種策略(頁面置換,進程調度等,每個裡面有幾種演算法)
- 互斥與死鎖相關的
- linux常用命令(問的時候都會給具體某一個場景)
- Linux內核相關(select、poll、epoll)
- 編程語言(這裡只說Java):把我之後的面經過一遍,Java感覺覆蓋的就差不多了,不過下麵還是分個類。
- Java基礎(面向對象、四個特性、重載重寫、static和final等等很多東西)
- 集合(HashMap、ConcurrentHashMap、各種List,最好結合源碼看)
- 併發和多線程(線程池、SYNC和Lock鎖機制、線程通信、volatile、ThreadLocal、CyclicBarrier、Atom包、CountDownLatch、AQS、CAS原理等等)
- JVM(記憶體模型、GC垃圾回收,包括分代,GC演算法,收集器、類載入和雙親委派、JVM調優,記憶體泄漏和記憶體溢出)
- IO/NIO相關
- 反射和代理、異常、Java8相關、序列化
- 設計模式(常用的,jdk中有的)
- Web相關(servlet、cookie/session、Spring)
阿裡面試題目範疇:
- 記憶體模型
- 類載入機制
- GC
- JVM調優
- 線程池原理
- 動態代理
- 悲觀鎖樂觀鎖
- 高併發問題
- 事務隔離級別
- 索引原理
- 限流
- 分庫分表
- 分散式事務提交
- 微服務
- dubbo原理
面試總結
公司一般都比較喜歡的人才特點:對技術有熱情,強硬的技術基礎實力;主動,善於團隊協作,善於總結思考。
技術基礎以及的問題多看看書準備,不懂的直接說不懂沒關係的;在項目細節上多把關一下,根據項目有針對性的談自己的技術亮點,能表達清楚,可以引導面試官來問你比較擅長的技術問題。
【文章福利】
現在是跳槽招聘季,為瞭解決小伙伴們的燃眉之急
小編也準備了一些JAVA程式員面試題,小伙伴可以試試。
需要的可以加小編QQ架構群:552391552,獲取!(內附答案詳解)