從七個方面,面試BAT大廠高級工程師,純乾貨!

来源:https://www.cnblogs.com/qiaogeli/archive/2019/08/26/11415638.html
-Advertisement-
Play Games

轉載註明:https://blog.csdn.net/WantFlyDaCheng/article/details/100078782 一、框架是重點,但別讓人感覺你只會山寨別人的代碼 二、別單純看單機版的框架,適當瞭解些分散式 三、資料庫方面,別就知道增刪改查,得瞭解性能優化 四、Java核心方面 ...


轉載註明:https://blog.csdn.net/WantFlyDaCheng/article/details/100078782

  • 一、框架是重點,但別讓人感覺你只會山寨別人的代碼
  • 二、別單純看單機版的框架,適當瞭解些分散式
  • 三、資料庫方面,別就知道增刪改查,得瞭解性能優化
  • 四、Java核心方面,圍繞數據結構和性能優化準備面試題
  • 五、Linux方面,至少瞭解如何看日誌排查問題
  • 六、通讀一段底層代碼,作為加分項
  • 七、一切的一切,把上述技能嵌入到你做過的項目里
  • 八、小結:本文更多講述的準備面試的方法

在上周,我密集面試了若幹位Java後端的候選人,工作經驗在3到5年間。我的標準其實不複雜:第一能幹活,第二Java基礎要好,第三最好熟悉些分散式框架,我相信其它公司招開發時,應該也照著這個標準來面的。

我也知道,不少候選人能力其實不差,但面試時沒準備或不會說,這樣的人可能在進團隊幹活後確實能達到期望,但可能就無法通過面試,但面試官總是只根據面試情況來判斷。

但現實情況是,大多數人可能面試前沒準備,或準備方法不得當。要知道,我們平時幹活更偏重於業務,不可能大量接觸到演算法,數據結構,底層代碼這類面試必問的問題點,換句話說,面試準備點和平時工作要點匹配度很小。

作為面試官,我只能根據候選人的回答來決定面試結果。不過,與人方便自己方便,所以我在本文里,將通過一些常用的問題來介紹面試的準備技巧。大家在看後一定會感嘆:只要方法得當,準備面試第一不難,第二用的時間也不會太多。

一、框架是重點,但別讓人感覺你只會山寨別人的代碼

在面試前,我會閱讀簡歷以查看候選人在框架方面的項目經驗,在候選人的項目介紹的環節,我也會著重關註候選人最近的框架經驗,目前比較熱門的是SSM。

不過,一般工作在5年內的候選人,大多僅僅是能“山寨”別人的代碼,也就是說能在現有框架的基礎上,照著別人寫的流程,擴展出新的功能模塊。比如要寫個股票掛單的功能模塊,是會模仿現有的下單流程,然後從前端到後端再到資料庫,依樣畫葫蘆寫一遍,最多把功能相關的代碼點改掉。

其實我們每個人都這樣過來的,但在面試時,如果你僅僅表現出這樣的能力,就和大多數人的水平差不多了,在這點就沒法體現出你的優勢了。

我們知道,如果單純使用SSM框架,大多數項目都會有痛點。比如資料庫性能差,或者業務模塊比較複雜,併發量比較高,用Spring MVC里的Controller無法滿足跳轉的需求。所以我一般還會主動問:你除了依照現有框架寫業務代碼時,還做了哪些改動?

我聽到的回答有:增加了Redis緩存,以避免頻繁調用一些不變的數據。或者,在MyBitas的xml里,select語句where條件有is null,即這個值有就增加一個where條件,對此,會對任何一個where增加一個不帶isnull的查詢條件,以免該語句當傳入參數都是null時,做全表掃描。或者,乾脆說,後端非同步返回的數據量很大,時間很長,我在項目里就調大了非同步返回的最大時間,或者對返回信息做了壓縮處理,以增加網路傳輸性能。

對於這個問題,我不在乎聽到什麼回答,我只關心回答符不符邏輯。一般只要答對,我就會給出“在框架層面有自己的體會,有一定的瞭解”,否則,我就只會給出“只能在項目經理帶領下編寫框架代碼,對框架本身瞭解不多”。

其實,在準備面試時,歸納框架里的要點並不難,我就不信所有人在做項目時一點積累也沒,只要你說出來,可以說,這方面你就碾壓了將近7成的競爭者。

二、別單純看單機版的框架,適當瞭解些分散式

此外,在描述項目里框架技術時,最好你再帶些分散式的技術。下麵我列些大家可以準備的分散式技術。

1、反向代理方面,nginx的基本配置,比如如何通過lua語言設置規則,如何設置session粘滯。如果可以,再看些nginx的底層,比如協議,集群設置,失效轉移等。

2、遠程調用dubbo方面,可以看下dubbo和zookeeper整合的知識點,再深一步,瞭解下dubbo底層的傳輸協議和序列化方式。

3、消息隊列方面,可以看下kafka或任意一種組件的使用方式,簡單點可以看下配置,工作組的設置,再深入點,可以看下Kafka集群,持久化的方式,以及發送消息是用長連接還是短攔截。

以上僅僅是用3個組件舉例,大家還可以看下Redis緩存,日誌框架,MyCAT分庫分表等。準備的方式有兩大類,第一是要會說怎麼用,這比較簡單,能通過配置文件搭建成一個功能模塊即可,第二是可以適當讀些底層代碼,以此瞭解下協議,集群和失效轉移之類的高級知識點。

如果能在面試中侃侃而談分散式組件的底層,那麼得到的評價就會比較好了,比如“深入瞭解框架底層”,或“框架經驗豐富”,這樣就算去面試架構師也行了,更何況是高級開發。

三、資料庫方面,別就知道增刪改查,得瞭解性能優化

在實際項目里,大多數程式員用到的可能僅僅是增刪改查,當我們用Mybatis時,這個情況更普遍。不過如果你面試時也這樣表現,估計你的能力就和其它競爭者差不多了。

這方面,你可以準備如下的技能。

1、SQL高級方面,比如group by, having,左連接,子查詢(帶in),行轉列等高級用法。

2、建表方面,你可以考慮下,你項目是用三範式還是反範式,理由是什麼?

3、尤其是優化,你可以準備下如何通過執行計劃查看SQL語句改進點的方式,或者其它能改善SQL性能的方式(比如建索引等)。

4、如果你感覺有能力,還可以準備些MySQL集群,MyCAT分庫分表的技能。比如通過LVS+Keepalived實現MySQL負載均衡,MyCAT的配置方式。同樣,如果可以,也看些相關的底層代碼。

哪怕你在前三點表現一般,那麼至少也能超越將近一般的候選人,尤其當你在SQL優化方面表現非常好,那麼你在面試高級開發時,資料庫層面一定是達標的,如果你連第四點也回答非常好,那麼恭喜你,你在資料庫方面的能力甚至達到了初級架構的級別。

四、Java核心方面,圍繞數據結構和性能優化準備面試題

Java核心這塊,網上的面試題很多,不過在此之外,大家還應當著重關註集合(即數據結構)和多線程併發這兩塊,在此基礎上,大家可以準備些設計模式和虛擬機的說辭。

下麵列些我一般會問的部分問題:

1、String a = "123"; String b = "123"; a==b的結果是什麼?這包含了記憶體,String存儲方式等諸多知識點。

2、HashMap里的hashcode方法和equal方法什麼時候需要重寫?如果不重寫會有什麼後果?對此大家可以進一步瞭解HashMap(甚至ConcurrentHashMap)的底層實現。

3、ArrayList和LinkedList底層實現有什麼差別?它們各自適用於哪些場合?對此大家也可以瞭解下相關底層代碼。

4、volatile關鍵字有什麼作用?由此展開,大家可以瞭解下線程記憶體和堆記憶體的差別。

5、CompletableFuture,這個是JDK1.8里的新特性,通過它怎麼實現多線程併發控制?

6、JVM里,new出來的對象是在哪個區?再深入一下,問下如何查看和優化JVM虛擬機記憶體。

7、Java的靜態代理和動態代理有什麼差別?最好結合底層代碼來說。

通過上述的問題點,我其實不僅僅停留在“會用”級別,比如我不會問如何在ArrayList里放元素。大家可以看到,上述問題包含了“多線程併發”,“JVM優化”,“數據結構對象底層代碼”等細節,大家也可以舉一反三,通過看一些高級知識,多準備些其它類似面試題。

我們知道,目前Java開發是以Web框架為主,那麼為什麼還要問Java核心知識點呢?我這個是有切身體會的。

之前在我團隊里,我見過兩個人,一個是就會幹活,具體表現是會用Java核心基本的API,而且也沒有深入瞭解的意願(估計不知道該怎麼深入瞭解),另一位平時專門會看些Java併發,虛擬機等的高級知識。過了半年以後,後者的能力快速升級到高級開發,由於對JAVA核心知識點瞭解很透徹,所以看一些分散式組件的底層實現沒什麼大問題。而前者,一直在重覆勞動,能力也只一直停留在“會幹活”的層面。

而在現實的面試中,如果不熟悉Java核心知識點,估計升高級開發都難,更別說是面試架構師級別的崗位了。

五、Linux方面,至少瞭解如何看日誌排查問題

如果候選人能證明自己有“排查問題”和“解決問題”的能力,這絕對是個加分項,但怎麼證明?

目前大多數的互聯網項目,都是部署在Linux上,也就是說,日誌都是在Linux,下麵歸納些實際的Linux操作。

1、能通過less命令打開文件,通過Shift+G到達文件底部,再通過?+關鍵字的方式來根據關鍵來搜索信息。

2、能通過grep的方式查關鍵字,具體用法是, grep 關鍵字 文件名,如果要兩次在結果里查找的話,就用grep 關鍵字1 文件名 | 關鍵字2 --color。最後--color是高亮關鍵字。

3、能通過vi來編輯文件。

4、能通過chmod來設置文件的許可權。

當然,還有更多更實用的Linux命令,但在實際面試過程中,不少候選人連一條linux命令也不知道。還是這句話,你哪怕知道些很基本的,也比一般人強了。

六、通讀一段底層代碼,作為加分項

如何證明自己對一個知識點非常瞭解?莫過於能通過底層代碼來說明。我在和不少工作經驗在5年之內的程式員溝通時,不少人認為這很難?確實,如果要通過閱讀底層代碼瞭解分散式組件,那難度不小,但如果如下部分的底層代碼,並不難懂。

1、ArrayList,LinkedList的底層代碼里,包含著基於數組和鏈表的實現方式,如果大家能以此講清楚擴容,“通過枚舉器遍歷“等方式,絕對能證明自己。

2、HashMap直接對應著Hash表這個數據結構,在HashMap的底層代碼里,包含著hashcode的put,get等的操作,甚至在ConcurrentHashMap里,還包含著Lock的邏輯。我相信,如果大家在面試中,看看而言ConcurrentHashMap,再結合在紙上邊說邊畫,那一定能征服面試官。

3、可以看下靜態代理和動態代理的實現方式,再深入一下,可以看下Spring AOP里的實現代碼。

4、或許Spirng IOC和MVC的底層實現代碼比較難看懂,但大家可以說些關鍵的類,根據關鍵流程說下它們的實現方式。

其實準備的底層代碼未必要多,而且也不限於在哪個方面,比如集合里基於紅黑樹的TreeSet,基於NIO的開源框架,甚至分散式組件的Dubbo,都可以準備。而且準備時未必要背出所有的底層(事實上很難做到),你只要能結合一些重要的類和方法,講清楚思路即可(比如講清楚HashMap如何通過hashCode快速定位)。

那麼在面試時,如何找到個好機會說出你準備好的上述底層代碼?在面試時,總會被問到集合,Spring MVC框架等相關知識點,你在回答時,順便說一句,“我還瞭解這塊的底層實現”,那麼面試官一定會追問,那麼你就可以說出來了。

不要小看這個對候選人的幫助,一旦你講了,只要意思到位,那麼最少能得到個“肯積極專業“的評價,如果描述很清楚,那麼評價就會升級到“熟悉Java核心技能(或Spring MVC),且基本功扎實”。要知道,面試中,很少有人能講清楚底層代碼,所以你拋出了這個話題,哪怕最後沒達到預期效果,面試官也不會由此對你降低評價。所以說,準備這塊絕對是“有百利而無一害”的掙錢買賣。

七、一切的一切,把上述技能嵌入到你做過的項目里

程中,我經常會聽到一些比較遺憾的回答,比如候選人對SQL優化技能講得頭頭是道,但最後得知,這是他平時自學時掌握的,並沒用在實際項目里。

當然這總比不說要好,所以我會寫下“在平時自學過SQL優化技能”,但如果在項目里實踐過,那麼我就會寫下“有實際資料庫SQL優化的技能”。大家可以對比下兩者的差別,一個是偏重理論,一個是直接能幹活了。其實,很多場景里,我就不信在實際項目里一定沒有實踐過SQL優化技能。

從這個案例中,我想告訴大家的是,你之前費了千辛萬苦(其實方法方向得到,也不用費太大精力)準備的很多技能和說辭,最後應該落實到你的實際項目里。

比如你有過在Linux日誌里查詢關鍵字排查問題的經驗,在描述時你可以帶一句,在之前的項目里我就這樣乾的。又如,你通過看底層代碼,瞭解了TreeSet和HashSet的差別以及它們的適用範圍,那麼你就可以回想下你之前做的項目,是否有個場景僅僅適用於TreeSet?如果有,那麼你就可以適當描述下項目的需求,然後說,通過讀底層代碼,我瞭解了兩者的差別,而且在這個實際需求里,我就用了TreeSet,而且我還專門做了對比性試驗,發現用TreeSet比HashSet要高xx個百分點。

請記得,“實踐經驗”一定比“理論經驗”值錢,而且大多數你知道的理論上的經驗,一定在你的項目里用過。所以,如果你僅僅讓面試官感覺你只有“理論經驗”,那就太虧了。

八、小結:本文更多講述的準備面試的方法
本文給出的面試題並不多,但本文並沒有打算給出太多的面試題。從本文里,大家更多看到的是面試官發現的諸多候選人的痛點。

本文的用意是讓大家別再重蹈別人的覆轍,這還不算,本文還給出了不少準備面試的方法。你的能力或許比別人出眾,但如果你準備面試的方式和別人差不多,或者就拿你在項目里乾的活來說事,而沒有歸納出你在項目中的亮點,那麼面試官還真的會看扁你。

本文里提到的方法和技能,如果能對大家有所幫助,請大家幫忙轉發”,或者通過評論來參與討論。

再次感謝大家讀完本文。
來源:http://rrd.me/ekVgF

覺得文章不錯的歡迎關註我的WX公眾號:程式員喬戈里
我是百度後臺開發工程師,哈工大電腦本碩,專註分享技術乾貨/編程資源/求職面試/成長感悟等,關註送5000G編程資源和自己整理的一份幫助不少人拿下java的offer的面經附答案,免費下載CSDN資源。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 文章瀏覽量統計,low的做法是:用戶每次瀏覽,前端會發送一個GET請求獲取一篇文章詳情時,會把這篇文章的瀏覽量 +1,存進資料庫里。 ...
  • 一、switch練習 註意:switch(int/String) 我們舉例,這裡傳入的是char類型,而實際上卻是'B',就是66 二、我們判斷一個學生成績的等級 三、源碼: d21_switch_exercise.java 地址:https://github.com/ruigege66/Java/ ...
  • [TOC] 原文鏈接: "Markdown模板" 一、概述 用Qt進行開發界面時,既想要實現友好的用戶交互又想界面漂亮,那麼自定義界面就必不可少。其中有一個操作就是是我們每一個Qter開發者都要會的,而且是經常進行的。 Qt::FramelessWindowHint這個屬性想必大家都使用過,有些同學 ...
  • 1 題目描述 數組中有一個數字出現的次數超過數組長度的一半,請找出這個數字。例如輸入一個長度為9的數組{1,2,3,2,2,2,5,4,2}。由於數字2在數組中出現了5次,超過數組長度的一半,因此輸出2。如果不存在則輸出0。 數組中有一個數字出現的次數超過數組長度的一半,請找出這個數字。例如輸入一個 ...
  • Spring 總覽及 IOC 容器的使用 —— Spring 官方文檔解讀(一) 什麼是 Spring? spring 這個詞在不同情況下有不同意義。可以指 Spring 框架本身,但更多地被用來表示 Spring 整個家族的產品。 設計理念 學習框架必須要知道它的設計理念,Spring 框架有著以 ...
  • 一、自己創建: 1.創建maven項目 2.pom.xml添加如下內容: 3.創建springboot項目啟動類: 二、Web下載基礎項目包 1.進入spring官網下載springboot項目包:http://https://start.spring.io/ 2.選擇需要的配置後下載: 3.下載後 ...
  • 基於鎖和線程的併發模型是目前最常用的一種併發模型,但是併發編程模型不僅僅只有這一種,瞭解和熟悉各種併發編程模型,在解決併發問題時會有更多思路。” ...
  • [TOC] Java實現發郵件功能 前言 電子郵件的應用場景非常廣泛,例如新用戶加入,即時發送優惠清單、通過郵件找回密碼、監聽後臺程式,出現異常自動郵件通知等。 本文以網易郵箱為例,通過Java代碼實現發送郵件功能。 開發環境 請參照: "基於SpringBoot構建分模塊項目" 代碼 1. pom ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...