阿里最新的java程式設計師面試題目
目錄
- 技術一面(23問)
- 技術二面(3大塊)
- 效能優化(21點)
- 專案實戰(34塊)
- JAVA方向技術考察點(15點)
- JAVA開發技術面試中可能問到的問題(17問)
阿里技術面試1
1.Java IO流的層次結構?
2.請說出常用的異常型別?
3.SKU的全稱是什麼,SKU與SPU的區別及關係?
4.FileInputStream 在使用完以後,不關閉流,想二次使用可以怎麼操作?
5.設計一個分步式登入系統?
6.Spring載入過程?
7.自己有沒有寫過類似Spring這樣的AOP事務?
8.Java中 try..catch 關閉流的語法糖?
9.如何設計一個秒殺系統?要考慮什麼?
10.有沒有遇到進線上GC,出現的症狀是什麼樣的,怎麼解決的?
11spring的載入過程?
12.atomic 與 volatile的區別?
13.Thread的 notify()給notifyAll()的區別?
14.notifiy()是喚醒的那一個執行緒?
15.Thread.sleep()喚醒以後是否需要重新競爭?
16.單例有多少種寫法? 有什麼區別? 你常用哪一種單例,為什麼用這種?
17.問一個Thread.join()相關的問題?
18.商品相關模組系統怎麼設計資料模型?
19.寫一個JAVA死鎖的列子?
20.如何解決死鎖?
21.GC回收演算法,及實現原理?
22.HashMap資料儲存結構? key重複了怎麼辦? 是如何解決的?
23.Spring AOP的實現原理,底層用什麼實現的?
阿里技術面試2
電話面試主要考察3塊內容:
- 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查詢。
JAVA方向技術考察點(補充):
- 掌握Java程式語言,包含io/nio/socket/multi threads/collection/concurrency等功能的使用;
- 熟練掌握jvm(sun hotspot和ibm j9)記憶體模型、gc垃圾回收調優等技能;
- 精通JVM,JMM,MVC架構,熟練使用struts2。
- 熟練使用spring、struts、ibatis構建應用系統。
- 熟練使用Servlet,jsp,freemark等前端技術。
- 熟練使用axis搭建基於SOAP協議的WebService服務介面。
- 熟練使用MAVEN構建專案工程。
- 熟練使用tomcat等web服務。
- 熟練使用mysql等關係型資料庫,熟悉mysql叢集搭建。
- 熟練使用redis等NOSQL技術。
- 熟悉tcp、http協議。
- 熟悉nginx、haproxy等配置。
- 熟悉javascript、ajax等技術。
- 熟悉主流分散式檔案系統FastDFS等。
- 熟悉JMS,可熟練使用ActiveMQ。
Java技術Leader要求能夠對於專案本身知其然知其所以然,不僅技術功力深還要業務能力強有很好的idea和業務sense,並且對技術充滿興趣和渴望,千萬不要面試官問一個問題答一個,呆板的表情完全看不出任何自己的想法。
面試中描述你做的每一個專案:你做了什麼工作?這些工作你解決了什麼問題?還有什麼困難沒有解決?這些困難在後續如何優化?優化後可以實現什麼功能?這些功能如何和中介軟體和分散式並行系統聯絡在一起??Java中介軟體方向訊息的傳輸方式mq長連線短連線
Java 虛擬機器有什麼優化?
- 底層計算機理解記憶體管理/資料探勘系統
- 可靠性和可用性如何理解~
- jsp 和sever lap對比
- 資料庫到介面,字符集轉化
- 基棧
- jvm優化cup高的時候如果分析和監控
- java curb突出細節問題
- 分散式快取文件如何分流
- 遷移資料庫垂直分割
- 高併發如何處理前端高併發應用層
- LB設計load balance
- 負載均衡
- 防網路攻擊
- 資料日誌事件監控後通知
- 資料庫事務實現的底層機制
- 字串空格輸入的網路攻擊
- Quartz框架的底層原理
- 資料庫同步中不通過資料庫引擎直接讀日誌等方式同步資料
如果你想學好JAVA這門技術,也想在IT行業拿高薪,可以進來看看 ,群裡有:Java工程化、高效能及分散式、高效能、深入淺出。高架構。效能調優、Spring,MyBatis,Netty原始碼分析和大資料等多個知識點。
如果你想拿高薪的,想學習的,想就業前景好的,想跟別人競爭能取得優勢的,想進阿里面試但擔心面試不過的,你都可以來,群號:828545509(小白和廣告勿擾)
阿里面試題
- 二叉樹的遍歷方式,前序、中序、後序和層序
- volatile關鍵字
- synchronized
- concurrentHashMap
- 鎖的優化策略
- 作業系統
專案部分
- 快取的使用,如果現在需要實現一個簡單的快取,供搜尋框中的ajax非同步請求呼叫,使用什麼結構?
- 記憶體中的快取不能一直存在,用什麼演算法定期將搜尋權重較低的entry去掉?
- TCP如何保證安全性
- 紅黑樹的問題,B+數
- JDK1.8中對HashMap的增強,如果一個桶上的節點數量過多,連結串列+陣列的結構就會轉換為紅黑樹。
- 專案中使用的單機伺服器,如果將它部署成分散式伺服器?
- MySQL的常見優化方式、定為慢查詢
- 手寫一個執行緒安全的單例模式
- 進阿里必會知識:
- 演算法和資料結構陣列、連結串列、二叉樹、佇列、棧的各種操作(效能,場景)
- 二分查詢和各種變種的二分查詢
- 各類排序演算法以及複雜度分析(快排、歸併、堆)
- 各類演算法題(手寫)
- 理解並可以分析時間和空間複雜度。
- 動態規劃(筆試回回有。。)、貪心。
- 紅黑樹、AVL樹、Hash樹、Tire樹、B樹、B+樹。
- 圖演算法(比較少,也就兩個最短路徑演算法理解吧)
- 計算機網路OSI7層模型(TCP4層)每層的協議
- url到頁面的過程
- HTTPhttp/https 1.0、1.1、2.0
- 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