1. 程式人生 > >JAVA架構師面試題,如何成為架構師

JAVA架構師面試題,如何成為架構師

基礎題目

  1. Java執行緒的狀態

  2. 程序和執行緒的區別,程序間如何通訊,執行緒間如何通訊

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

  4. Cookie和Session的區別

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

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

  7. equals方法實現

  8. 面向物件

  9. 執行緒狀態,BLOCKED和WAITING有什麼區別

  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 。

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

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

還有佇列中介軟體。如訊息推送,可以先把訊息寫入資料庫,推送放佇列伺服器上,由推送伺服器去佇列獲取處理,這樣就可以將訊息放資料庫和佇列裡後直接給使用者反饋,推送過程則由推送伺服器和佇列伺服器完成,好處非同步處理、緩解伺服器壓力,解藕系統。

以上純粹是常用的技術,還有很多自己慢慢去摸索吧;因為要知道的東西很多,所以要成為一名合格的架構師,必須要有強大的自學能力,沒有人會手把手的教給你所有的東西。

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

架構師還要針對業務特點、系統的效能要求提出能解決問題成本最低的設計方案才合格,人家一個幾百人使用者的系統,訪問量不大,資料量小,你給人家上叢集、上分散式儲存、上高階伺服器,為了架構而架構,這是最扯淡的,架構師的作用就是第一滿足業務需求,第二最低的硬體網路成本和技術維護成本。

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

程式設計師應該需要都有自知之明,會就是會,不會就是不會,網際網路發展迅速的時代,只能跟上時代的進步,才不會被淘汰。


相關推薦

JAVA架構試題如何成為架構-待完善。。。

基礎題目 1.Java執行緒的狀態 1.1、Java中的執行緒的狀態分為6種 初始(NEW):新建立了一個執行緒物件,但還沒有呼叫start()方法。 執行(RUNNABLE):Java執行緒中將就緒(ready)和執行中(running)兩種狀態籠統的成為“執

JAVA架構試題如何成為架構

基礎題目 Java執行緒的狀態 程序和執行緒的區別,程序間如何通訊,執行緒間如何通訊 HashMap的資料結構是什麼?如何實現的。和HashTable,ConcurrentHashMap的區別 Cookie和Session的區別 索引有什麼用?如何建索引? ArrayList是如何實現的,Arr

2017年終巨獻阿裏、騰訊最新Java程序員試題準備好進BAT了嗎

電商 als 下載 坐標 序列化 equals 比較 通過 研究 Java基礎 進程和線程的區別; Java的並發、多線程、線程模型; 什麽是線程池,如何使用? 數據一致性如何保證;Synchronized關鍵字,類鎖,方法鎖,重入鎖; Java中實現多態的機制是什麽; 如

java中高級試題 虛擬機JVM調優垃圾回收多線程內存模型

mybatis mys set 內存 集合 實現 runable ringbuf mon 面試問題: 一、Java基礎方面: 1、Java面相對象的思想的理解(主要是多態): http://blog.csdn.net/zhaojw_420/article/details/7

36道Java經典基礎試題面試可不能栽在這上面!

在我們日常找工作的過程中,面試絕對是必不可少的,所以要想進到自己想去的那家公司,必須首先把面試做好,這裡小編精選了一些基礎的java面試題,供正在找工作的,或者準備找工作的程式設計師們使用。 1.”static”關鍵字是什麼意思?Java中是否可以覆蓋(override)一個privat

java 面向物件試題問答題構造方法抽象類繼承多型介面異常總結;

一,構造方法的特點 面向物件的思想是如何在java展現的呢? 就是通過類和物件 類是一組相關的屬性和行為的集合。是一個抽象的概念。 物件是該類事物的具體表現形式。具體存在的個體。 一、抽象類的抽象方法的特點是什麼? 被abstract修飾的類稱為抽象類 特點: 1、抽象類不能有物件(不能用new關鍵字來例項化

Java架構試題全分享你離架構還有多遠?

經常面試一些候選人,整理了下我面試使用的題目,陸陸續續整理出來的題目很多,所以每次會抽一部分來問。答案會在後面的文章中逐漸釋出出來。 基礎題目 Java執行緒的狀態 程序和執行緒的區別,程序間如何通訊,執行緒間如何通訊 HashMap的資料結構是什麼?如何實現的。和HashT

Java資深架構詳解大廠多執行緒試題細談併發程式設計深造歷程

  多執行緒、執行緒池 多執行緒是實現併發機制的一種有效手段。程序和執行緒一樣,都是實現併發的一個基本單位。執行緒是比程序更小的執行單位,執行緒是程序的基礎之上進行進一步的劃分。所謂多執行緒是指一個程序在執行過程中可以產生多個更小的程式單元,這些更小的單元稱為執行緒,這

成為一個Java架構要學習哪些知識?架構試題又會有什麼http://mp.weixin.qq.com/s/CVlFWzZziI4RnNqwL50IxA

在網上找了一個牛人給出的題目 牛人出的面試題如下: 1. struts,spring,hibernate這樣的開源框架,他們的歷史侷限性在哪裡?在何種情況下會不適合用這些框架? 答: struts是以請求回答方式為基礎的.ajax,flash等富客戶端越來越多了..... spring是由

阿裏P8架構總結Java並發試題(精選)

htable 檢測 之前 方式 可用 架構師 str shm 為什麽 一、什麽是線程? 線程是操作系統能夠進行運算調度的最小單位,它被包含在進程之中,是進程中的實際運作單位。程序員可以通過它進行多處理器編程,你可以使用多線程對運算密集型任務提速。比如,如果一個線程完成一個

Java架構試題全集:Java基礎+技術框架+系統架構+分散式系統

Java架構師面試題全集:Java基礎+技術框架+系統架構+分散式系統 優知學院 2018-10-10 18:45:00     基礎題目 Java執行緒的狀態 程序和執行緒的區別,程序間如何通訊,執行緒間如何通訊 HashM

阿里p8架構分享:50道2018年最經典的試題(含標準答案!)

(一小部分題的答案被我略作改動) 1、什麼是執行緒區域性變數? 執行緒區域性變數是侷限於執行緒內部的變數,屬於執行緒自身所有,不在多個執行緒間共享。Java 提供 ThreadLocal 類來支援執行緒區域性變數,是一種實現執行緒安全的方式。但是在管理環境下(如 web

一篇文章讓你豁然開朗成為架構你必須了解的一些疑問

有一點 同事 繼續 模式 常見 瓶頸 功能實現 很多 獨立 前言:我先介紹一下我的新同事,公司好多同事都這麽叫他James,有10年開發經驗的架構師,之前在人人網待過,之後我們也聊了很多。 在聊天過程中,我們也聊到了他為什麽離開人人網,也聊到了他在成為架構師的道路上的辛酸歷

2018年最全23個阿里架構試題(總結篇)

想要進入大型企業的話,首先要有豐富的工作經驗和專案經驗,其次就是有好的表達能力,能說會道。 從程式設計師成長為架構師,需要幾年?從架構師升任CTO,又需要幾年?成長沒有一蹴而就,雞湯喝再多,終究是要回到現實,腳踏實地。 咱們接下來說說一些架構師面試常見的面試題: 1、String,Str

一篇文章讓你豁然開朗成為架構你必須瞭解的一些疑問

前言: 我先介紹一下我的新同事,公司好多同事都這麼叫他James,有10年開發經驗的架構師,之前在人人網待過,之後我們也聊了很多。 在聊天過程中,我們也聊到了他為什麼離開人人網,也聊到了他在成為架構師的道路上的辛酸歷程,聊過後,才發現,離開人人網的原因和他的架構師之路和我

2018乾貨成為架構的四階段資料分享。

本文分享的架構師資料會很多。寫在分享前,我們今天聊一下IT職業發展的問題,篇幅較以往或許有點長,也掇中痛點,請用心看心去。我作為工作好些年的老司機,將帶你洞穿你的IT技術未來之路該怎麼走,同時會授予你一套架構真經。 職業發展瓶頸? 也許你現在已經工作好些年了,大把的年輕還幹著初級的活。或許你已經是中

架構試題參考

一、牛人出的面試題如下:  1. struts,spring,hibernate這樣的開源框架,他們的歷史侷限性在哪裡?在何種情況下會不適合用這些框架?  2. 如果要設計一個搜尋引擎,像google那樣只有兩個頁面,要求效能最大化,web方面應該如何設計?(不需要考慮搜尋的邏輯)  3. 如果要設計一個

架構試題

nbsp inf img 分享圖片 .com mage bsp png 技術分享 架構師面試題

ETL架構試題(中文)

本部分的題目來自Kimball的ETL Toolkit著作,原著未直接給出答案。這裡的中文題目和答案是我參考其原著按自己的理解整理而來的,僅供參考。對於其中不確切的地方,歡迎大家一起溝通。有興趣的朋友可以直接閱讀原著。  分析  1.什麼是邏輯資料對映?它對ETL專案組的作用是什麼?  2.在資料倉庫專案中,

Java面試常會被問到的經典試題學習或者求職你都要好好掌握

cookie 異常類 shu data 區別 origin 目的 tro jdk和jre Java現在的熱度雖然有所下降,但是,學Java的人依舊很多。。Java的崗位也是滲透很多。那麽,那些經典的Java知識點,你能看到問題就能說出一二三嗎?來一起看看。。 1.JDK和