Java架構師面試題全集:Java基礎+技術框架+系統架構+分散式系統
Java架構師面試題全集:Java基礎+技術框架+系統架構+分散式系統
優知學院 2018-10-10 18:45:00
基礎題目
- Java執行緒的狀態
- 程序和執行緒的區別,程序間如何通訊,執行緒間如何通訊
- HashMap的資料結構是什麼?如何實現的。和HashTable,ConcurrentHashMap的區別
- Cookie和Session的區別
- 索引有什麼用?如何建索引?
- ArrayList是如何實現的,ArrayList和LinkedList的區別?ArrayList如何實現擴容。
- equals方法實現
- 面向物件
- 執行緒狀態,BLOCKED和WAITING有什麼區別
- JVM如何載入位元組碼檔案
- JVM GC,GC演算法。
- 什麼情況會出現Full GC,什麼情況會出現yong GC。
- JVM記憶體模型
- Java執行時資料區
- 事務的實現原理
技術深度
- 有沒有看過JDK原始碼,看過的類實現原理是什麼。
- HTTP協議
- TCP協議
- 一致性Hash演算法
- JVM如何載入位元組碼檔案
- 類載入器如何解除安裝位元組碼
- IO和NIO的區別,NIO優點
- Java執行緒池的實現原理,keepAliveTime等引數的作用。
- HTTP連線池實現原理
- 資料庫連線池實現原理
- 資料庫的實現原理
技術框架
- 看過哪些開源框架的原始碼
- 為什麼要用Redis,Redis有哪些優缺點?Redis如何實現擴容?
- Netty是如何使用執行緒池的,為什麼這麼使用
- 為什麼要使用Spring,Spring的優缺點有哪些
- Spring的IOC容器初始化流程
- Spring的IOC容器實現原理,為什麼可以通過byName和ByType找到Bean
- Spring AOP實現原理
- 訊息中介軟體是如何實現的,技術難點有哪些
系統架構
- 如何搭建一個高可用系統
- 哪些設計模式可以增加系統的可擴充套件性
- 介紹設計模式,如模板模式,命令模式,策略模式,介面卡模式、橋接模式、裝飾模式,觀察者模式,狀態模式,訪問者模式。
- 抽象能力,怎麼提高研發效率。
- 什麼是高內聚低耦合,請舉例子如何實現
- 什麼情況用介面,什麼情況用訊息
- 如果AB兩個系統互相依賴,如何解除依賴
- 如何寫一篇設計文件,目錄是什麼
- 什麼場景應該拆分系統,什麼場景應該合併系統
- 系統和模組的區別,分別在什麼場景下使用
分散式系統
- 分散式事務,兩階段提交。
- 如何實現分散式鎖
- 如何實現分散式Session
- 如何保證訊息的一致性
- 負載均衡
- 正向代理(客戶端代理)和反向代理(伺服器端代理)
- CDN實現原理
- 怎麼提升系統的QPS和吞吐量
實戰能力
- 有沒有處理過線上問題?出現記憶體洩露,CPU利用率標高,應用無響應時如何處理的。
- 開發中有沒有遇到什麼技術問題?如何解決的
- 如果有幾十億的白名單,每天白天需要高併發查詢,晚上需要更新一次,如何設計這個功能。
- 新浪微博是如何實現把微博推給訂閱者
- Google是如何在一秒內把搜尋結果返回給使用者的。
- 12306網站的訂票系統如何實現,如何保證不會票不被超賣。
- 如何實現一個秒殺系統,保證只有幾位使用者能買到某件商品。
軟能力
- 如何學習一項新技術,比如如何學習Java的,重點學習什麼
- 有關注哪些新的技術
- 工作任務非常多非常雜時如何處理
- 專案出現延遲如何處理
- 和同事的設計思路不一樣怎麼處理
- 如何保證開發質量
- 職業規劃是什麼?短期,長期目標是什麼
- 團隊的規劃是什麼
- 能介紹下從工作到現在自己的成長在那裡
JAVA架構師的標準
1.首先你至少可以承擔一個高階java工程師。
- 熟練使用各種框架以及實現的原理
- JVM虛擬機器原理、JVM調優,懂得jvm能讓你寫出效能更好的程式碼
- 池技術:什麼物件池連線池,執行緒池
- java反射技術,寫框架必備的技術
- java各種集合物件的實現原理,瞭解這些可以讓你在解決問題時選擇合適的資料結構,高效的解決問題,比如hashmap的實現原理,好多五年以上經驗的人都弄不清楚,還有為什擴容時有效能問題?不弄清楚這些原理,就寫不出高效的程式碼。
總之一句話越基礎的東西越重要,很多人認為自己會用它們寫程式碼了,其實僅僅是知道如何呼叫api而已,離會用還差的遠。
2.其次,各種資料結構和演算法(基礎很重要)
熟練使用各種資料結構和演算法,陣列、雜湊、連結串列、排序樹...,一句話要麼是時間換空間要麼是空間換時間,這裡展開可以說一大堆,需要有一定的應用經驗,用於解決各種效能或業務上的問題。
3.熟練使用linux作業系統,Linux線上排除故障,以及效能監控等。
4.熟悉tcp協議
建立連線三次握手和斷開連線四次握手的整個過程,不瞭解的話,無法對高併發網路應用做優化。
熟悉http協議,尤其是http頭,我發現好多工作五年以上的都弄不清session和cookie的生命週期以及它們之間的關聯。
5.系統叢集、負載均衡、反向代理、動靜分離,網站靜態化 。
- 分散式儲存系統nfs,fastdfs,tfs,Hadoop瞭解他們的優缺點,適用場景 。
- 分散式快取技術memcached,redis,提高系統性能必備,一句話,把硬碟上的內容放到記憶體裡來提速,順便提個演算法一致性hash 。
- 工具nginx必備技能超級好用,高效能,基本不會掛掉的伺服器,功能多多,解決各種問題。
6.資料庫的設計能力
MySQL慢查詢日誌分析,主從複製的配置,至少要成為半個mysql dba。
其他nosql資料庫如mongodb。
7.還有 佇列中介軟體
如訊息推送,可以先把訊息寫入資料庫,推送放佇列伺服器上,由推送伺服器去佇列獲取處理,這樣就可以將訊息放資料庫和佇列裡後直接給使用者反饋,推送過程則由推送伺服器和佇列伺服器完成,好處非同步處理、緩解伺服器壓力,解藕系統。
以上純粹是常用的技術,還有很多自己慢慢去摸索吧,因為要知道的東西很多,所以要成為一名合格的架構師,必須要有強大的自學能力,沒有人會手把手的教給你所有的東西。
以上這些都是成為架構師的必要條件,不是充分條件。
8.服務業務
架構師還要針對業務特點、系統的效能要求提出能解決問題成本最低的設計方案才合格,人家一個幾百人使用者的系統,訪問量不大,資料量小,你給人家上叢集、上分散式儲存、上高階伺服器,為了架構而架構,這是最扯淡的,架構師的作用就是第一滿足業務需求,第二最低的硬體網路成本和技術維護成本。
架構師還要根據業務發展階段,提前預見發展到下一個階段系統架構的解決方案,並且設計當前架構時將架構的升級擴充套件考慮進去,做到易於升級;否則等系統瓶頸來了,出問題了再去出方案,或現有架構無法擴充套件直接扔掉重做,或擴充套件麻煩問題一大堆,這會對企業造成損失。
更多架構設計系列專題
資料獲取方式
關注+轉發後,私信關鍵詞 【架構】即可獲取!
重要的事情說三遍,轉發、轉發、轉發後再