Java 架構師面試題

基礎題目java

  1. Java線程的狀態mysql

  2. 進程和線程的區別,進程間如何通信,線程間如何通信linux

  3. HashMap的數據結構是什麼?如何實現的。和HashTable,ConcurrentHashMap的區別nginx

  4. Cookie和Session的區別程序員

  5. 索引有什麼用?如何建索引?面試

  6. ArrayList是如何實現的,ArrayList和LinkedList的區別?ArrayList如何實現擴容。redis

  7. equals方法實現算法

  8. 面向對象sql

  9. 線程狀態,BLOCKED和WAITING有什麼區別mongodb

  10. JVM如何加載字節碼文件

  11. JVM GC,GC算法。

  12. 什麼狀況會出現Full GC,什麼狀況會出現yong GC。

  13. JVM內存模型

  14. Java運行時數據區

  15. 事務的實現原理

技術深度

  1. 有沒有看過JDK源碼,看過的類實現原理是什麼。

  2. HTTP協議

  3. TCP協議

  4. 一致性Hash算法

  5. JVM如何加載字節碼文件

  6. 類加載器如何卸載字節碼

  7. IO和NIO的區別,NIO優勢

  8. Java線程池的實現原理,keepAliveTime等參數的做用。

  9. HTTP鏈接池實現原理

  10. 數據庫鏈接池實現原理

  11. 數據庫的實現原理

技術框架

  1. 看過哪些開源框架的源碼

  2. 爲何要用Redis,Redis有哪些優缺點?Redis如何實現擴容?

  3. Netty是如何使用線程池的,爲何這麼使用

  4. 爲何要使用Spring,Spring的優缺點有哪些

  5. Spring的IOC容器初始化流程

  6. Spring的IOC容器實現原理,爲何能夠經過byName和ByType找到Bean

  7. Spring AOP實現原理

  8. 消息中間件是如何實現的,技術難點有哪些

系統架構

  1. 如何搭建一個高可用系統

  2. 哪些設計模式能夠增長系統的可擴展性

  3. 介紹設計模式,如模板模式,命令模式,策略模式,適配器模式、橋接模式、裝飾模式,觀察者模式,狀態模式,訪問者模式。

  4. 抽象能力,怎麼提升研發效率。

  5. 什麼是高內聚低耦合,請舉例子如何實現

  6. 什麼狀況用接口,什麼狀況用消息

  7. 若是AB兩個系統互相依賴,如何解除依賴

  8. 如何寫一篇設計文檔,目錄是什麼

  9. 什麼場景應該拆分系統,什麼場景應該合併系統

  10. 系統和模塊的區別,分別在什麼場景下使用

分佈式系統

  1. 分佈式事務,兩階段提交。

  2. 如何實現分佈式鎖

  3. 如何實現分佈式Session

  4. 如何保證消息的一致性

  5. 負載均衡

  6. 正向代理(客戶端代理)和反向代理(服務器端代理)

  7. CDN實現原理

  8. 怎麼提高系統的QPS和吞吐量

實戰能力

  1. 有沒有處理過線上問題?出現內存泄露,CPU利用率標高,應用無響應時如何處理的。

  2. 開發中有沒有遇到什麼技術問題?如何解決的

  3. 若是有幾十億的白名單,天天白天須要高併發查詢,晚上須要更新一次,如何設計這個功能。

  4. 新浪微博是如何實現把微博推給訂閱者

  5. Google是如何在一秒內把搜索結果返回給用戶的。

  6. 12306網站的訂票系統如何實現,如何保證不會票不被超賣。

  7. 如何實現一個秒殺系統,保證只有幾位用戶能買到某件商品。

軟能力

  1. 如何學習一項新技術,好比如何學習Java的,重點學習什麼

  2. 有關注哪些新的技術

  3. 工做任務很是多很是雜時如何處理

  4. 項目出現延遲如何處理

  5. 和同事的設計思路不同怎麼處理

  6. 如何保證開發質量

  7. 職業規劃是什麼?短時間,長期目標是什麼

  8. 團隊的規劃是什麼

  9. 能介紹下從工做到如今本身的成長在那裏

JAVA架構師的水準

既然java架構師,首先你要是一個高級java攻城屍,熟練使用各類框架,並知道它們實現的原理。jvm虛擬機原理、調優,懂得jvm能讓你寫出性能更好的代碼;

池技術,什麼對象池,鏈接池,線程池...:;java反射技術,寫框架必備的技術,可是有嚴重的性能問題,替代方案java字節碼技術;nio,沒什麼好說的,值得注意的是"直接內存"的特色,使用場景;java多線程同步異步;

java各類集合對象的實現原理,瞭解這些可讓你在解決問題時選擇合適的數據結構,高效的解決問題,好比hashmap的實現原理,好多五年以上經驗的人都弄不清楚,還有爲什擴容時有性能問題?不弄清楚這些原理,就寫不出高效的代碼,還會認爲本身作的很對;

總之一句話越基礎的東西越重要,不少人認爲本身會用它們寫代碼了,其實僅僅是知道如何調用api而已,離會用還差的遠。

熟練使用各類數據結構和算法,數組、哈希、鏈表、排序樹...,一句話要麼是時間換空間要麼是空間換時間,這裏展開能夠說一大堆,須要有必定的應用經驗,用於解決各類性能或業務上的問題;有時間再補充。

熟練使用linux操做系統,必備,沒什麼好說的 。

熟悉tcp協議,建立鏈接三次握手和斷開鏈接四次握手的整個過程,不瞭解的話,沒法對高併發網絡應用作優化; 熟悉http協議,尤爲是http頭,我發現好多工做五年以上的都弄不清session和cookie的生命週期以及它們之間的關聯。

系統集羣、負載均衡、反向代理、動靜分離,網站靜態化 。

分佈式存儲系統nfs,fastdfs,tfs,Hadoop瞭解他們的優缺點,適用場景 。

分佈式緩存技術memcached,redis,提升系統性能必備,一句話,把硬盤上的內容放到內存裏來提速,順便提個算法一致性hash 。點擊這裏有一套Redis面試題答案。

工具nginx必備技能超級好用,高性能,基本不會掛掉的服務器,功能多多,解決各類問題。

數據庫的設計能力,mysql必備,最基礎的數據庫工具,免費好用,對它基本的參數優化,慢查詢日誌分析,主從複製的配置,至少要成爲半個mysql dba。其餘nosql數據庫如mongodb。

還有隊列中間件。如消息推送,能夠先把消息寫入數據庫,推送放隊列服務器上,由推送服務器去隊列獲取處理,這樣就能夠將消息放數據庫和隊列裏後直接給用戶反饋,推送過程則由推送服務器和隊列服務器完成,好處異步處理、緩解服務器壓力,解藕系統。

以上純粹是經常使用的技術,還有不少本身慢慢去摸索吧;由於要知道的東西不少,因此要成爲一名合格的架構師,必需要有強大的自學能力,沒有人會手把手的教給你全部的東西。

想成爲架構師不是懂了一大堆技術就能夠了,這些是解決問題的基礎、是工具,不懂這些怎麼去提解決方案呢?這是成爲架構師的必要條件。

架構師還要針對業務特色、系統的性能要求提出能解決問題成本最低的設計方案才合格,人家一個幾百人用戶的系統,訪問量不大,數據量小,你給人家上集羣、上分佈式存儲、上高端服務器,爲了架構而架構,這是最扯淡的,架構師的做用就是第一知足業務需求,第二最低的硬件網絡成本和技術維護成本。

架構師還要根據業務發展階段,提早預見發展到下一個階段系統架構的解決方案,而且設計當前架構時將架構的升級擴展考慮進去,作到易於升級;不然等系統瓶頸來了,出問題了再去出方案,或現有架構沒法擴展直接扔掉重作,或擴展麻煩問題一大堆,這會對企業形成損失。

程序員應該須要都有自知之明,會就是會,不會就是不會,互聯網發展迅速的時代,只能跟上時代的進步,纔不會被淘汰。

相關文章
相關標籤/搜索