阿裡面試題目目錄
技術一面(基礎面試題目)
技術二面(技術深度、技術原理)
項目實戰(項目模拟面試)
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原理
面試總結
公司一般都比較喜歡的人才特點:對技術有熱情,強硬的技術基礎實力;主動,善于團隊協作,善于總結思考。
技術基礎以及的問題多看看書準備,不懂的直接說不懂沒關系的;在項目細節上多把關一下,根據項目有針對性的談自己的技術亮點,能表達清楚,可以引導面試官來問你比較擅長的技術問題。
---------------------
原文:https://blog.csdn.net/pangziaichi/article/details/87896920