Java架構(gòu)師面試題全分享,你離架構(gòu)師還有多遠(yuǎn)?
經(jīng)常面試一些候選人,整理了下我面試使用的題目,陸陸續(xù)續(xù)整理出來的題目很多,所以每次會(huì)抽一部分來問。答案會(huì)在后面的文章中逐漸發(fā)布出來。
基礎(chǔ)題目
- Java線程的狀態(tài)
- 進(jìn)程和線程的區(qū)別,進(jìn)程間如何通訊,線程間如何通訊
- HashMap的數(shù)據(jù)結(jié)構(gòu)是什么?如何實(shí)現(xiàn)的。和HashTable,ConcurrentHashMap的區(qū)別
- Cookie和Session的區(qū)別
- 索引有什么用?如何建索引?
- ArrayList是如何實(shí)現(xiàn)的,ArrayList和LinkedList的區(qū)別?ArrayList如何實(shí)現(xiàn)擴(kuò)容。
- equals方法實(shí)現(xiàn)
面向?qū)ο?/strong>
- 線程狀態(tài),BLOCKED和WAITING有什么區(qū)別
- JVM如何加載字節(jié)碼文件
- JVM GC,GC算法。
- 什么情況會(huì)出現(xiàn)Full GC,什么情況會(huì)出現(xiàn)yong GC。
- JVM內(nèi)存模型
- Java運(yùn)行時(shí)數(shù)據(jù)區(qū)
- 事務(wù)的實(shí)現(xiàn)原理
技術(shù)深度
- 有沒有看過JDK源碼,看過的類實(shí)現(xiàn)原理是什么。
- HTTP協(xié)議
- TCP協(xié)議
- 一致性Hash算法
- JVM如何加載字節(jié)碼文件
- 類加載器如何卸載字節(jié)碼
- IO和NIO的區(qū)別,NIO優(yōu)點(diǎn)
- Java線程池的實(shí)現(xiàn)原理,keepAliveTime等參數(shù)的作用。
- HTTP連接池實(shí)現(xiàn)原理
- 數(shù)據(jù)庫連接池實(shí)現(xiàn)原理
- 數(shù)據(jù)庫的實(shí)現(xiàn)原理
技術(shù)框架
- 看過哪些開源框架的源碼
- 為什么要用Redis,Redis有哪些優(yōu)缺點(diǎn)?Redis如何實(shí)現(xiàn)擴(kuò)容?
- Netty是如何使用線程池的,為什么這么使用
- 為什么要使用Spring,Spring的優(yōu)缺點(diǎn)有哪些
- Spring的IOC容器初始化流程
- Spring的IOC容器實(shí)現(xiàn)原理,為什么可以通過byName和ByType找到Bean
- Spring AOP實(shí)現(xiàn)原理
- 消息中間件是如何實(shí)現(xiàn)的,技術(shù)難點(diǎn)有哪些
系統(tǒng)架構(gòu)
- 如何搭建一個(gè)高可用系統(tǒng)
- 哪些設(shè)計(jì)模式可以增加系統(tǒng)的可擴(kuò)展性
- 介紹設(shè)計(jì)模式,如模板模式,命令模式,策略模式,適配器模式、橋接模式、裝飾模式,觀察者模式,狀態(tài)模式,訪問者模式。
- 抽象能力,怎么提高研發(fā)效率。
- 什么是高內(nèi)聚低耦合,請(qǐng)舉例子如何實(shí)現(xiàn)
- 什么情況用接口,什么情況用消息
- 如果AB兩個(gè)系統(tǒng)互相依賴,如何解除依賴
- 如何寫一篇設(shè)計(jì)文檔,目錄是什么
- 什么場(chǎng)景應(yīng)該拆分系統(tǒng),什么場(chǎng)景應(yīng)該合并系統(tǒng)
- 系統(tǒng)和模塊的區(qū)別,分別在什么場(chǎng)景下使用
分布式系統(tǒng)
- 分布式事務(wù),兩階段提交。
- 如何實(shí)現(xiàn)分布式鎖
- 如何實(shí)現(xiàn)分布式Session
- 如何保證消息的一致性
- 負(fù)載均衡
- 正向代理(客戶端代理)和反向代理(服務(wù)器端代理)
- CDN實(shí)現(xiàn)原理
- 怎么提升系統(tǒng)的QPS和吞吐量
實(shí)戰(zhàn)能力
- 有沒有處理過線上問題?出現(xiàn)內(nèi)存泄露,CPU利用率標(biāo)高,應(yīng)用無響應(yīng)時(shí)如何處理的。
- 開發(fā)中有沒有遇到什么技術(shù)問題?如何解決的
- 如果有幾十億的白名單,每天白天需要高并發(fā)查詢,晚上需要更新一次,如何設(shè)計(jì)這個(gè)功能。
- 新浪微博是如何實(shí)現(xiàn)把微博推給訂閱者
- Google是如何在一秒內(nèi)把搜索結(jié)果返回給用戶的。
- 12306網(wǎng)站的訂票系統(tǒng)如何實(shí)現(xiàn),如何保證不會(huì)票不被超賣。
- 如何實(shí)現(xiàn)一個(gè)秒殺系統(tǒng),保證只有幾位用戶能買到某件商品。
軟能力
- 如何學(xué)習(xí)一項(xiàng)新技術(shù),比如如何學(xué)習(xí)Java的,重點(diǎn)學(xué)習(xí)什么
- 有關(guān)注哪些新的技術(shù)
- 工作任務(wù)非常多非常雜時(shí)如何處理
- 項(xiàng)目出現(xiàn)延遲如何處理
- 和同事的設(shè)計(jì)思路不一樣怎么處理
- 如何保證開發(fā)質(zhì)量
- 職業(yè)規(guī)劃是什么?短期,長(zhǎng)期目標(biāo)是什么
- 團(tuán)隊(duì)的規(guī)劃是什么
- 能介紹下從工作到現(xiàn)在自己的成長(zhǎng)在那里
JAVA架構(gòu)師的水準(zhǔn)
既然java架構(gòu)師,首先你要是一個(gè)高級(jí)java攻城尸,熟練使用各種框架,并知道它們實(shí)現(xiàn)的原理。jvm虛擬機(jī)原理、調(diào)優(yōu),懂得jvm能讓你寫出性能更好的代碼;池技術(shù),什么對(duì)象池,連接池,線程池...:;java反射技術(shù),寫框架必備的技術(shù),但是有嚴(yán)重的性能問題,替代方案java字節(jié)碼技術(shù);nio,沒什么好說的,值得注意的是"直接內(nèi)存"的特點(diǎn),使用場(chǎng)景;java多線程同步異步;java各種集合對(duì)象的實(shí)現(xiàn)原理,了解這些可以讓你在解決問題時(shí)選擇合適的數(shù)據(jù)結(jié)構(gòu),高效的解決問題,比如hashmap的實(shí)現(xiàn)原理,好多五年以上經(jīng)驗(yàn)的人都弄不清楚,還有為什擴(kuò)容時(shí)有性能問題?不弄清楚這些原理,就寫不出高效的代碼,還會(huì)認(rèn)為自己做的很對(duì);總之一句話越基礎(chǔ)的東西越重要,很多人認(rèn)為自己會(huì)用它們寫代碼了,其實(shí)僅僅是知道如何調(diào)用api而已,離會(huì)用還差的遠(yuǎn)。
熟練使用各種數(shù)據(jù)結(jié)構(gòu)和算法,數(shù)組、哈希、鏈表、排序樹...,一句話要么是時(shí)間換空間要么是空間換時(shí)間,這里展開可以說一大堆,需要有一定的應(yīng)用經(jīng)驗(yàn),用于解決各種性能或業(yè)務(wù)上的問題;有時(shí)間再補(bǔ)充。
熟練使用linux操作系統(tǒng),必備,沒什么好說的 。
熟悉tcp協(xié)議,創(chuàng)建連接三次握手和斷開連接四次握手的整個(gè)過程,不了解的話,無法對(duì)高并發(fā)網(wǎng)絡(luò)應(yīng)用做優(yōu)化; 熟悉http協(xié)議,尤其是http頭,我發(fā)現(xiàn)好多工作五年以上的都弄不清session和cookie的生命周期以及它們之間的關(guān)聯(lián)。
系統(tǒng)集群、負(fù)載均衡、反向代理、動(dòng)靜分離,網(wǎng)站靜態(tài)化 。
分布式存儲(chǔ)系統(tǒng)nfs,fastdfs,tfs,Hadoop了解他們的優(yōu)缺點(diǎn),適用場(chǎng)景 。
分布式緩存技術(shù)memcached,redis,提高系統(tǒng)性能必備,一句話,把硬盤上的內(nèi)容放到內(nèi)存里來提速,順便提個(gè)算法一致性hash 。
工具nginx必備技能超級(jí)好用,高性能,基本不會(huì)掛掉的服務(wù)器,功能多多,解決各種問題。
數(shù)據(jù)庫的設(shè)計(jì)能力,mysql必備,最基礎(chǔ)的數(shù)據(jù)庫工具,免費(fèi)好用,對(duì)它基本的參數(shù)優(yōu)化,慢查詢?nèi)罩痉治?,主從?fù)制的配置,至少要成為半個(gè)mysql dba。其他nosql數(shù)據(jù)庫如mongodb。
還有隊(duì)列中間件。如消息推送,可以先把消息寫入數(shù)據(jù)庫,推送放隊(duì)列服務(wù)器上,由推送服務(wù)器去隊(duì)列獲取處理,這樣就可以將消息放數(shù)據(jù)庫和隊(duì)列里后直接給用戶反饋,推送過程則由推送服務(wù)器和隊(duì)列服務(wù)器完成,好處異步處理、緩解服務(wù)器壓力,解藕系統(tǒng)。
以上純粹是常用的技術(shù),還有很多自己慢慢去摸索吧;因?yàn)橐赖臇|西很多,所以要成為一名合格的架構(gòu)師,必須要有強(qiáng)大的自學(xué)能力,沒有人會(huì)手把手的教給你所有的東西。
想成為架構(gòu)師不是懂了一大堆技術(shù)就可以了,這些是解決問題的基礎(chǔ)、是工具,不懂這些怎么去提解決方案呢?這是成為架構(gòu)師的必要條件。
架構(gòu)師還要針對(duì)業(yè)務(wù)特點(diǎn)、系統(tǒng)的性能要求提出能解決問題成本***的設(shè)計(jì)方案才合格,人家一個(gè)幾百人用戶的系統(tǒng),訪問量不大,數(shù)據(jù)量小,你給人家上集群、上分布式存儲(chǔ)、上高端服務(wù)器,為了架構(gòu)而架構(gòu),這是最扯淡的,架構(gòu)師的作用就是***滿足業(yè)務(wù)需求,第二***的硬件網(wǎng)絡(luò)成本和技術(shù)維護(hù)成本。
架構(gòu)師還要根據(jù)業(yè)務(wù)發(fā)展階段,提前預(yù)見發(fā)展到下一個(gè)階段系統(tǒng)架構(gòu)的解決方案,并且設(shè)計(jì)當(dāng)前架構(gòu)時(shí)將架構(gòu)的升級(jí)擴(kuò)展考慮進(jìn)去,做到易于升級(jí);否則等系統(tǒng)瓶頸來了,出問題了再去出方案,或現(xiàn)有架構(gòu)無法擴(kuò)展直接扔掉重做,或擴(kuò)展麻煩問題一大堆,這會(huì)對(duì)企業(yè)造成損失。
程序員應(yīng)該需要都有自知之明,會(huì)就是會(huì),不會(huì)就是不會(huì),互聯(lián)網(wǎng)發(fā)展迅速的時(shí)代,只能跟上時(shí)代的進(jìn)步,才不會(huì)被淘汰。