自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Java后端這樣面試,拿到Offer的幾率是99%

開(kāi)發(fā) 后端 開(kāi)發(fā)工具
在上周,我密集面試了若干位 Java 后端候選人,工作經(jīng)驗(yàn)在 3 到 5 年間。

在上周,我密集面試了若干位 Java 后端候選人,工作經(jīng)驗(yàn)在 3 到 5 年間。

[[271092]]

圖片來(lái)自 Pexels

我的標(biāo)準(zhǔn)其實(shí)不復(fù)雜,有如下三點(diǎn):

  • 能干活。
  • Java 基礎(chǔ)要好。
  • ***熟悉些分布式框架。

相信其它公司招初級(jí)開(kāi)發(fā)時(shí),應(yīng)該也照著這個(gè)標(biāo)準(zhǔn)來(lái)面試的。我也知道,不少候選人能力其實(shí)不差,但面試時(shí)沒(méi)準(zhǔn)備或不會(huì)說(shuō)。

這樣的人可能進(jìn)團(tuán)隊(duì)干活后確實(shí)能達(dá)到期望,但可能無(wú)法通過(guò)面試,面試官只根據(jù)面試情況來(lái)判斷。

要知道,我們平時(shí)干活更偏重于業(yè)務(wù),不可能大量接觸到算法,數(shù)據(jù)結(jié)構(gòu),底層代碼這類面試必問(wèn)的問(wèn)題點(diǎn)。

換句話說(shuō),面試準(zhǔn)備點(diǎn)和平時(shí)工作要點(diǎn)匹配度很小。

[[271093]]

作為面試官,我只能根據(jù)候選人的回答來(lái)決定面試結(jié)果。不過(guò),與人方便自己方便。所以我在本文里,將通過(guò)一些常用的問(wèn)題來(lái)介紹面試的準(zhǔn)備技巧。

大家在看后一定會(huì)感嘆:只要方法得當(dāng),準(zhǔn)備面試***不難,第二用的時(shí)間也不會(huì)太多。

框架是重點(diǎn),但別讓人感覺(jué)你只會(huì)山寨別人的代碼

在面試前,我會(huì)閱讀簡(jiǎn)歷以查看候選人在框架方面的項(xiàng)目經(jīng)驗(yàn),在候選人的項(xiàng)目介紹的環(huán)節(jié),我也會(huì)著重關(guān)注候選人最近的框架經(jīng)驗(yàn),目前比較熱門(mén)的是 SSM。

不過(guò),一般工作在 5 年內(nèi)的候選人,大多僅僅是能“山寨”別人的代碼,也就是說(shuō)能在現(xiàn)有框架的基礎(chǔ)上,照著別人寫(xiě)的流程,擴(kuò)展出新的功能模塊。

比如要寫(xiě)個(gè)股票掛單的功能模塊,是會(huì)模仿現(xiàn)有的下單流程,然后從前端到后端再到數(shù)據(jù)庫(kù),依樣畫(huà)葫蘆寫(xiě)一遍,最多把功能相關(guān)的代碼點(diǎn)改掉。

其實(shí)我們每個(gè)人都這樣過(guò)來(lái)的,但在面試時(shí),如果你僅僅表現(xiàn)出這樣的能力,就和大多數(shù)人的水平差不多了,在這點(diǎn)就沒(méi)法體現(xiàn)出你的優(yōu)勢(shì)了。

我們知道,如果單純使用 SSM 框架,大多數(shù)項(xiàng)目都會(huì)有痛點(diǎn)。比如數(shù)據(jù)庫(kù)性能差,或者業(yè)務(wù)模塊比較復(fù)雜,并發(fā)量比較高,用 Spring MVC 里的 Controller 無(wú)法滿足跳轉(zhuǎn)的需求。

所以我一般還會(huì)主動(dòng)問(wèn):你除了依照現(xiàn)有框架寫(xiě)業(yè)務(wù)代碼時(shí),還做了哪些改動(dòng)?

我聽(tīng)到的回答有:

  • 增加了 Redis 緩存,以避免頻繁調(diào)用一些不變的數(shù)據(jù)。
  • 或者,在 MyBatis 的 XML 里,Select 語(yǔ)句 Where 條件有 Isnull,即這個(gè)值有就增加一個(gè) Where 條件。

對(duì)此,會(huì)對(duì)任何一個(gè) Where 增加一個(gè)不帶 Isnull 的查詢條件,以免該語(yǔ)句當(dāng)傳入?yún)?shù)都是 Null 時(shí),做全表掃描。

  • 或者干脆說(shuō),后端異步返回的數(shù)據(jù)量很大,時(shí)間很長(zhǎng),我在項(xiàng)目里就調(diào)大了異步返回的***時(shí)間,或者對(duì)返回信息做了壓縮處理,以增加網(wǎng)絡(luò)傳輸性能。

對(duì)于這個(gè)問(wèn)題,我不在乎聽(tīng)到什么回答,我只關(guān)心回答符不符合邏輯。一般只要答對(duì),我就會(huì)給出“在框架層面有自己的體會(huì),有一定的了解”的面試評(píng)價(jià)。

否則,我就只會(huì)給出“只能在項(xiàng)目經(jīng)理帶領(lǐng)下編寫(xiě)框架代碼,對(duì)框架本身了解不多”。

其實(shí),在準(zhǔn)備面試時(shí),歸納框架里的要點(diǎn)并不難,我就不信所有人在做項(xiàng)目時(shí)一點(diǎn)積累也沒(méi),只要你說(shuō)出來(lái),可以說(shuō),這方面你就碾壓了將近 7 成的競(jìng)爭(zhēng)者。

別只看單機(jī)版的框架,分布式也要了解

此外,在描述項(xiàng)目里框架技術(shù)時(shí),***你再帶些分布式的技術(shù)。下面我列些大家可以準(zhǔn)備的分布式技術(shù):

  • 反向代理方面,Nginx 的基本配置,比如如何通過(guò) Lua 語(yǔ)言設(shè)置規(guī)則,如何設(shè)置 Session 粘滯。如果可以,再看些 Nginx 的底層,比如協(xié)議,集群設(shè)置,失效轉(zhuǎn)移等。
  • 遠(yuǎn)程調(diào)用 Dubbo 方面,可以看下 Dubbo 和 Zookeeper 整合的知識(shí)點(diǎn),再深一步,了解下 Dubbo 底層的傳輸協(xié)議和序列化方式。
  • 消息隊(duì)列方面,可以看下 Kafka 或任意一種組件的使用方式,簡(jiǎn)單點(diǎn)可以看下配置,工作組的設(shè)置,再深入點(diǎn),可以看下 Kafka 集群,持久化的方式,以及發(fā)送消息是用長(zhǎng)連接還是短連接。

以上僅僅是用 3 個(gè)組件舉例,大家還可以看下 Redis 緩存,日志框架,MyCAT 分庫(kù)分表等。

準(zhǔn)備的方式有兩大類:

  • 要會(huì)說(shuō)怎么用,這比較簡(jiǎn)單,能通過(guò)配置文件搭建成一個(gè)功能模塊即可。
  • 可以適當(dāng)讀些底層代碼,以此了解下協(xié)議,集群和失效轉(zhuǎn)移之類的高級(jí)知識(shí)點(diǎn)。

如果能在面試中侃侃而談分布式組件的底層,那么得到的評(píng)價(jià)就會(huì)比較好了,比如“深入了解框架底層”,或“框架經(jīng)驗(yàn)豐富”,這樣就算去面試架構(gòu)師也行了,更何況是高級(jí)開(kāi)發(fā)。

對(duì)于數(shù)據(jù)庫(kù),別只知道增刪改查,得了解性能優(yōu)化

在實(shí)際項(xiàng)目里,大多數(shù)程序員用到的可能僅僅是增刪改查,當(dāng)我們用 MyBatis 時(shí),這個(gè)情況更普遍。不過(guò)如果你面試時(shí)也這樣表現(xiàn),估計(jì)你的能力就和其他競(jìng)爭(zhēng)者差不多了。

這方面,你可以準(zhǔn)備如下的技能:

  • SQL 高級(jí)方面,比如 Group By,Having,左連接,子查詢(帶 in),行轉(zhuǎn)列等高級(jí)用法。
  • 建表方面,你可以考慮下,項(xiàng)目是用三范式還是反范式,理由是什么?
  • 尤其是優(yōu)化,你可以準(zhǔn)備下如何通過(guò)執(zhí)行計(jì)劃查看 SQL 語(yǔ)句改進(jìn)點(diǎn)的方式,或者其他能改善 SQL 性能的方式(比如建索引等)。
  • 如果你感覺(jué)有能力,還可以準(zhǔn)備些 MySQL 集群,MyCAT 分庫(kù)分表的技能。比如通過(guò) LVS+Keepalived 實(shí)現(xiàn) MySQL 負(fù)載均衡,MyCAT 的配置方式。同樣,如果可以,也看些相關(guān)的底層代碼。

哪怕你在前三點(diǎn)表現(xiàn)一般,那么至少也能超越將近一半的候選人,尤其當(dāng)你在 SQL 優(yōu)化方面表現(xiàn)非常好,那么你在面試高級(jí)開(kāi)發(fā)時(shí),數(shù)據(jù)庫(kù)層面一定是達(dá)標(biāo)的。

如果你連第四點(diǎn)也回答非常好,那么恭喜你,你在數(shù)據(jù)庫(kù)方面的能力甚至達(dá)到了初級(jí)架構(gòu)的級(jí)別。

Java 核心,圍繞數(shù)據(jù)結(jié)構(gòu)和性能優(yōu)化準(zhǔn)備面試題

Java 核心這塊,網(wǎng)上的面試題很多,不過(guò)在此之外,大家還應(yīng)當(dāng)著重關(guān)注集合(即數(shù)據(jù)結(jié)構(gòu))和多線程并發(fā)這兩塊。在此基礎(chǔ)上,大家可以準(zhǔn)備些設(shè)計(jì)模式和虛擬機(jī)的說(shuō)辭。

下面列些我一般會(huì)問(wèn)的部分問(wèn)題:

  • String a = "123";String b = "123";a==b 的結(jié)果是什么?這包含了內(nèi)存,String 存儲(chǔ)方式等諸多知識(shí)點(diǎn)。
  • HashMap 里的 HashCode 方法和 Equal 方法什么時(shí)候需要重寫(xiě)?如果不重寫(xiě)會(huì)有什么后果?對(duì)此大家可以進(jìn)一步了解 HashMap(甚至 ConcurrentHashMap)的底層實(shí)現(xiàn)。
  • ArrayList 和 LinkedList 底層實(shí)現(xiàn)有什么差別?它們各自適用于哪些場(chǎng)合?對(duì)此大家也可以了解下相關(guān)底層代碼。
  • Volatile 關(guān)鍵字有什么作用?由此展開(kāi),大家可以了解下線程內(nèi)存和堆內(nèi)存的差別。
  • CompletableFuture,這個(gè)是 JDK 1.8 里的新特性,通過(guò)它怎么實(shí)現(xiàn)多線程并發(fā)控制?
  • JVM 里,New 出來(lái)的對(duì)象是在哪個(gè)區(qū)?再深入一下,問(wèn)下如何查看和優(yōu)化 JVM 虛擬機(jī)內(nèi)存。
  • Java 的靜態(tài)代理和動(dòng)態(tài)代理有什么差別?***結(jié)合底層代碼來(lái)說(shuō)。

通過(guò)上述的問(wèn)題點(diǎn),我其實(shí)不僅僅停留在“會(huì)用”級(jí)別,比如我不會(huì)問(wèn)如何在 ArrayList 里放元素。

大家可以看到,上述問(wèn)題包含了“多線程并發(fā)”,“JVM 優(yōu)化”,“數(shù)據(jù)結(jié)構(gòu)對(duì)象底層代碼”等細(xì)節(jié),大家也可以舉一反三,通過(guò)看一些高級(jí)知識(shí),多準(zhǔn)備些其他類似面試題。

我們知道,目前 Java 開(kāi)發(fā)是以 Web 框架為主,那么為什么還要問(wèn) Java 核心知識(shí)點(diǎn)呢?我這個(gè)是有切身體會(huì)的。

之前在我團(tuán)隊(duì)里,我見(jiàn)過(guò)兩個(gè)人,一個(gè)是就會(huì)干活,具體表現(xiàn)是會(huì)用 Java 核心基本的 API,而且也沒(méi)有深入了解的意愿(估計(jì)不知道該怎么深入了解),另一位平時(shí)專門(mén)會(huì)看些 Java 并發(fā),虛擬機(jī)等的高級(jí)知識(shí)。

過(guò)了半年以后,后者的能力快速升級(jí)到高級(jí)開(kāi)發(fā),由于對(duì) Java 核心知識(shí)點(diǎn)了解很透徹,所以看一些分布式組件的底層實(shí)現(xiàn)沒(méi)什么大問(wèn)題。而前者,一直在重復(fù)勞動(dòng),能力也只一直停留在“會(huì)干活”的層面。

而在現(xiàn)實(shí)的面試中,如果不熟悉 Java 核心知識(shí)點(diǎn),估計(jì)升高級(jí)開(kāi)發(fā)都難,更別說(shuō)是面試架構(gòu)師級(jí)別的崗位了。

Linux 方面,至少了解如何看日志排查問(wèn)題

如果候選人能證明自己有“排查問(wèn)題”和“解決問(wèn)題”的能力,這絕對(duì)是個(gè)加分項(xiàng),但怎么證明?

目前大多數(shù)的互聯(lián)網(wǎng)項(xiàng)目,都是部署在 Linux 上,也就是說(shuō),日志都是在 Linux。

下面歸納些實(shí)際的 Linux 操作:

  • 能通過(guò) Less 命令打開(kāi)文件,通過(guò) Shift+G 到達(dá)文件底部,再通過(guò) ?+ 關(guān)鍵字的方式來(lái)根據(jù)關(guān)鍵來(lái)搜索信息。
  • 能通過(guò) Grep 的方式查關(guān)鍵字,具體用法是,Grep 關(guān)鍵字 文件名,如果要兩次在結(jié)果里查找的話,就用 Grep 關(guān)鍵字 1 文件名 | 關(guān)鍵字 2 --color。***--color 是高亮關(guān)鍵字。
  • 能通過(guò) VI 來(lái)編輯文件。
  • 能通過(guò) Chmod 來(lái)設(shè)置文件的權(quán)限

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

通讀一段底層代碼,作為加分項(xiàng)

如何證明自己對(duì)一個(gè)知識(shí)點(diǎn)非常了解?莫過(guò)于能通過(guò)底層代碼來(lái)說(shuō)明。我在和不少工作經(jīng)驗(yàn)在 5 年之內(nèi)的程序員溝通時(shí),不少人認(rèn)為這很難?

確實(shí),如果要通過(guò)閱讀底層代碼了解分布式組件,那難度不小,但如果如下部分的底層代碼,并不難懂:

  • ArrayList,LinkedList 的底層代碼里,包含著基于數(shù)組和鏈表的實(shí)現(xiàn)方式,如果大家能以此講清楚擴(kuò)容,“通過(guò)枚舉器遍歷“等方式,絕對(duì)能證明自己。
  • HashMap 直接對(duì)應(yīng)著 Hash 表這個(gè)數(shù)據(jù)結(jié)構(gòu),在 HashMap 的底層代碼里,包含著 HashCode 的Put,Get等的操作,甚至在 ConcurrentHashMap 里,還包含著 Lock 的邏輯。

如果大家在面試中,看看而言 ConcurrentHashMap,再結(jié)合在紙上邊說(shuō)邊畫(huà),那一定能征服面試官。

  • 可以看下靜態(tài)代理和動(dòng)態(tài)代理的實(shí)現(xiàn)方式,再深入一下,可以看下 Spring AOP 里的實(shí)現(xiàn)代碼。
  • 或許 Spring IOC 和 MVC 的底層實(shí)現(xiàn)代碼比較難看懂,但大家可以說(shuō)些關(guān)鍵的類,根據(jù)關(guān)鍵流程說(shuō)下它們的實(shí)現(xiàn)方式。

其實(shí)準(zhǔn)備的底層代碼未必要多,而且也不限于在哪個(gè)方面,比如集合里基于紅黑樹(shù)的 TreeSet,基于 NIO 的開(kāi)源框架,甚至分布式組件的 Dubbo,都可以準(zhǔn)備。

而且準(zhǔn)備時(shí)未必要背出所有的底層(事實(shí)上很難做到),你只要能結(jié)合一些重要的類和方法,講清楚思路即可(比如講清楚 HashMap 如何通過(guò) HashCode 快速定位)。

那么在面試時(shí),如何找到個(gè)好機(jī)會(huì)說(shuō)出你準(zhǔn)備好的上述底層代碼?

在面試時(shí),總會(huì)被問(wèn)到集合,Spring MVC 框架等相關(guān)知識(shí)點(diǎn),你在回答時(shí),順便說(shuō)一句,“我還了解這塊的底層實(shí)現(xiàn)”,那么面試官一定會(huì)追問(wèn),那么你就可以說(shuō)出來(lái)了。

不要小看這個(gè)對(duì)候選人的幫助,一旦你講了,只要意思到位,那么最少能得到個(gè)“積極專業(yè)“的評(píng)價(jià),如果描述很清楚,那么評(píng)價(jià)就會(huì)升級(jí)到“熟悉 Java 核心技能(或 Spring MVC),且基本功扎實(shí)”。

要知道,面試中,很少有人能講清楚底層代碼,所以你拋出了這個(gè)話題,哪怕***沒(méi)達(dá)到預(yù)期效果,面試官也不會(huì)由此對(duì)你降低評(píng)價(jià)。

所以說(shuō),準(zhǔn)備這塊絕對(duì)是“有百利而無(wú)一害”的掙錢(qián)買(mǎi)賣(mài)。

切記切記,把上述技能嵌入到你的項(xiàng)目里

在面試過(guò)程中,我經(jīng)常會(huì)聽(tīng)到一些比較遺憾的回答,比如候選人對(duì) SQL 優(yōu)化技能講得頭頭是道,但***得知,這是他平時(shí)自學(xué)時(shí)掌握的,并沒(méi)用在實(shí)際項(xiàng)目里。

當(dāng)然這總比不說(shuō)要好,所以我會(huì)寫(xiě)下“在平時(shí)自學(xué)過(guò) SQL 優(yōu)化技能”,但如果在項(xiàng)目里實(shí)踐過(guò),那么我就會(huì)寫(xiě)下“有實(shí)際數(shù)據(jù)庫(kù) SQL 優(yōu)化的技能”。

大家可以對(duì)比下兩者的差別,一個(gè)是偏重理論,一個(gè)是直接能干活了。其實(shí),很多場(chǎng)景里,我就不信在實(shí)際項(xiàng)目里一定沒(méi)有實(shí)踐過(guò) SQL 優(yōu)化技能。

從這個(gè)案例中,我想告訴大家的是,你之前費(fèi)了千辛萬(wàn)苦(其實(shí)方法方向得到,也不用費(fèi)太大精力)準(zhǔn)備的很多技能和說(shuō)辭,***應(yīng)該落實(shí)到你的實(shí)際項(xiàng)目里。

比如你有過(guò)在 Linux 日志里查詢關(guān)鍵字排查問(wèn)題的經(jīng)驗(yàn),在描述時(shí)你可以帶一句,在之前的項(xiàng)目里我就這樣干的。

又如,你通過(guò)看底層代碼,了解了 TreeSet 和 HashSet 的差別以及它們的適用范圍,那么你可以回想你之前做的項(xiàng)目,是否有個(gè)場(chǎng)景僅僅適用于 TreeSet?

如果有,那么你就可以適當(dāng)描述下項(xiàng)目的需求,然后說(shuō),通過(guò)讀底層代碼,我了解了兩者的差別,而且在這個(gè)實(shí)際需求里,我就用了 TreeSet,而且我還專門(mén)做了對(duì)比性試驗(yàn),發(fā)現(xiàn)用 TreeSet 比 HashSet 要高 xx 個(gè)百分點(diǎn)。

請(qǐng)記得,“實(shí)踐經(jīng)驗(yàn)”一定比“理論經(jīng)驗(yàn)”值錢(qián),而且大多數(shù)你知道的理論上的經(jīng)驗(yàn),一定在你的項(xiàng)目里用過(guò)。

所以,如果你僅僅讓面試官感覺(jué)你只有“理論經(jīng)驗(yàn)”,那就太虧了。

小結(jié):本文更多講述的準(zhǔn)備面試的方法

本文給出的面試題并不多,但本文并沒(méi)有打算給出太多的面試題。從本文里,大家更多看到的是面試官發(fā)現(xiàn)的諸多候選人的痛點(diǎn)。

本文的用意是讓大家別再重蹈別人的覆轍,因此給出了不少準(zhǔn)備面試的方法。

你的能力或許比別人出眾,但如果你準(zhǔn)備面試的方式和別人差不多,或者就拿你在項(xiàng)目里干的活來(lái)說(shuō)事,而沒(méi)有歸納出你在項(xiàng)目中的亮點(diǎn),那么面試官還真的會(huì)看扁你。

作者:hsm_computer

簡(jiǎn)介:著有《Java Web輕量級(jí)開(kāi)發(fā)面試教程》和《Java核心技術(shù)及面試指南》

 

責(zé)任編輯:武曉燕 來(lái)源: 博客園
相關(guān)推薦

2018-05-23 14:22:27

程序員技能溝通

2018-04-02 14:42:20

面試程序員簡(jiǎn)歷

2018-05-23 09:11:42

微信Android開(kāi)發(fā)面試

2015-05-12 10:33:09

程序員代碼

2015-04-20 11:33:34

MySQLDBAFacebook of

2015-07-20 17:04:03

offer騰訊面試面試總結(jié)

2023-11-13 08:34:01

Java編程習(xí)慣

2022-04-02 18:37:25

面試

2014-04-23 10:49:48

Offer巨頭Offer面試

2020-12-10 08:43:17

垃圾回收JVM

2024-03-05 07:31:59

CASvalue原子性

2024-03-06 08:00:56

javaAQS原生

2018-03-05 17:32:06

開(kāi)發(fā)者編程面試

2024-09-18 06:30:00

2018-12-21 10:52:03

Java后端開(kāi)發(fā)面試

2015-09-08 10:06:18

JavaSocket編程通信

2020-04-20 08:35:48

HTTP HTTPS網(wǎng)絡(luò)協(xié)議

2018-03-15 10:21:50

程序員面試低級(jí)錯(cuò)誤

2015-11-12 10:32:13

程序員FaceBook

2022-04-29 14:08:50

技術(shù)人工智能
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)