天天看點

史上最全阿裡技術面試題目【轉】題目目錄一:阿裡技術一面(基礎掌握牢固)阿裡技術二面(技術原理、個人擅長的項目)JAVA開發技術面試可能問到的問題?項目部分進阿裡必會知識:阿裡面試題目範疇:阿裡面試總結

題目目錄

  1. 技術一面(基礎面試題目)
  2. 技術二面(技術深度、技術原理)
  3. 項目實戰(項目模拟面試)
  4. JAVA開發技術常問的問題
  5. 阿裡必會知識
  6. 阿裡面試範疇
  7. 阿裡面試總結

一:阿裡技術一面(基礎掌握牢固)

  1. 常用的異常類型?
  2. session
  3. java鎖
  4. gc原理
  5. hashmap
  6. listlink arraylist 差別
  7. aop 原理
  8. 多線程
  9. kafka 原理和容錯
  10. spark hadoop 原理
  11. redis 同步機制
  12. classLoader 機制
  13. Http 協定
  14. cookie的限制
  15. 如何設計一個分步式登入系統?
  16. Spring加載過程?
  17. 自己有沒有寫過類似Spring這樣的AOP事務?
  18. spring的加載過程?
  19. atomic 與 volatile的差別?
  20. Thread的 notify()給notifyAll()的差別?
  21. notifiy()是喚醒的那一個線程?
  22. Thread.sleep()喚醒以後是否需要重新競争?
  23. 單例有多少種寫法? 有什麼差別? 你常用哪一種單例,為什麼用這種?
  24. 問一個Thread.join()相關的問題?
  25. 寫一個JAVA死鎖的列子?
  26. 如何解決死鎖?
  27. GC回收算法,及實作原理?
  28. HashMap資料存儲結構? key重複了怎麼辦? 是如何解決的?
  29. Spring AOP的實作原理,底層用什麼實作的?

阿裡技術二面(技術原理、個人擅長的項目)

重點是面試技術原理,以及對技術的熱情和專研程度:

  1. Java的進階知識
  2. 開源架構的原理
  3. JVM
  4. 多線程
  5. 高并發
  6. 中間件
  7. 之前項目經曆,運用的技術,遇到的問題,如何解決,個人有什麼收獲和成長;
  8. 對于技術的熱情(平時是否看些技術書籍,逛論壇,寫部落格,寫源代碼或程式等);

JAVA開發技術面試可能問到的問題?

  1. 我們主要考核的是網絡nio 分布式資料庫高并發大資料
  2. 自定義表格的實作?
  3. 動态表單設計?
  4. in-jvm(必考)以及jmm緩存模型如何調優?
  5. 常用的RPC架構
  6. nio和io
  7. 并發程式設計,設計模式
  8. 地圖元件?
  9. hashmap有什麼漏洞會導緻他變慢?
  10. 如何給hashmap的key對象設計他的hashcode?
  11. 泛型通配符?在什麼情況下使用?
  12. 後端方面:redis?分布式架構dubbo(阿裡巴巴開源架構)?設計模式?
  13. 場景式的問題:秒殺,能列出常見的排隊、驗證碼、庫存扣減方式對系統高并發的影響?
  14. 能根據實際的需要建構緩存結構提高提高網站的通路速度,熟練使用ehcache、oscache,了解memcache。
  15. 了解基于dns輪詢的負載均衡,熟練配置web伺服器實作負載均衡,程式級能綜合使用基于hash或取模等手段實作軟負載。
  16. 熟悉分布式資料庫設計和優化技術,熟練使用mysql、oracle、SqlServer等主流資料庫,熟悉hadoop hbase mangodb redis ehcache、oscache memcache。對于大資料量的資料庫處理采用分表分庫、資料庫讀寫分離、建立緩存等手段優化性能。
  17. 熟練掌握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)

阿裡面試題目範疇:

  1. 記憶體模型
  2. 類加載機制
  3. GC
  4. JVM調優
  5. 線程池原理
  6. 動态代理
  7. 悲觀鎖樂觀鎖
  8. 高并發問題
  9. 事務隔離級别
  10. 索引原理
  11. 限流
  12. 分庫分表
  13. 分布式事務送出
  14. 微服務
  15. dubbo原理

阿裡面試總結

阿裡比較喜歡的人才特點:對技術有熱情,強硬的技術基礎實力;主動,善于團隊協作,善于總結思考。

技術基礎以及的問題多看看書準備,不懂的直接說不懂沒關系的;在項目細節上多把關一下,根據項目有針對性的談自己的技術亮點,能表達清楚,可以引導面試官來問你比較擅長的技術問題。

題目目錄

繼續閱讀