大廠面試復(fù)盤

作為一位二本畢業(yè),非計(jì)算機(jī)專業(yè)的學(xué)生來(lái)說(shuō),先后在0-20小公司拷肌,外包,100-499的中小公司做java開(kāi)發(fā)旨巷,目前終于通過(guò)大廠面試巨缘,下面來(lái)看看整個(gè)面試過(guò)程

一面:電話面試

1、Java重寫(xiě)equals 為什么要重寫(xiě)hashcode?

答:如果重寫(xiě)了equals不去重寫(xiě)hashcode那么就有兩個(gè)對(duì)象equlas相等采呐,hashcode不一樣若锁,對(duì)于hashSet來(lái)說(shuō),因?yàn)閔ashcode不一樣計(jì)算的數(shù)組位置下標(biāo)也不一樣斧吐,這樣兩個(gè)對(duì)象都能存到這個(gè)Set集合里面又固。這就違背了Set不能裝重復(fù)對(duì)象的設(shè)定。這樣包括hashmap在內(nèi)的只要已hashCode未基礎(chǔ)的各種集合無(wú)法正常去判斷一個(gè)對(duì)象煤率。

2仰冠、介紹一下java常用的集合類,底層數(shù)據(jù)結(jié)構(gòu)蝶糯,線程安全不安全

答:介紹了ArrayList LinkedList HashMap HashSet HashTable??concurrenthashmap 詳細(xì)介紹一番洋只。(面試必問(wèn),已經(jīng)老油條了)

3昼捍、說(shuō)一下hashMap的put方法流程

答: 巴拉巴拉一大堆识虚,重點(diǎn)要分1.7 和1.8講,以及講清楚了1.7的鏈表頭插法導(dǎo)致并發(fā)擴(kuò)容的時(shí)候的形成的環(huán)形鏈表導(dǎo)致的死鎖問(wèn)題端三。1.8改成尾插法來(lái)解決這個(gè)問(wèn)題舷礼。1.8的紅黑樹(shù)引進(jìn)。什么時(shí)候會(huì)變身紅黑樹(shù)郊闯。(面試必問(wèn)妻献,必須的)

4、new一個(gè)hashMap 傳入的容量為10 最終new 出來(lái)的map的數(shù)組長(zhǎng)度是多少?

答 是16

hashMap 的數(shù)組長(zhǎng)度總是2的n次方团赁,至于為什么 源碼這么設(shè)定的育拨,不太清除為什么這么設(shè)定。(看了源碼也不知道)

5欢摄、volitale關(guān)鍵字用過(guò)嗎熬丧,它能解決什么問(wèn)題?

答:解決并發(fā)問(wèn)題的線程之間的可見(jiàn)性問(wèn)題,當(dāng)多個(gè)線程對(duì)同一個(gè)變量進(jìn)行操作的時(shí)候怀挠,該線程并不能感知到別的線程已經(jīng)修改了這個(gè)變量析蝴。volitale是對(duì)JAVA對(duì)MESI緩存一致性協(xié)議給出的關(guān)鍵字害捕。之后又扯了什么是MESI協(xié)議,cpu從從主內(nèi)存讀變量到工作內(nèi)存這一大堆流程闷畸。volitale還能防止指令重排尝盼。之后面試官接著問(wèn)讀寫(xiě)屏障,這我就支支吾吾打不上來(lái)了佑菩。(這塊射擊的底層計(jì)算機(jī)知識(shí)太多盾沫,問(wèn)深了打不上來(lái))

6、線程池用過(guò)嗎殿漠,有哪些核心參數(shù)赴精,線程池的工作流程是什么樣子的。

答 :核心線程數(shù)? 最大線程數(shù) 最大空閑時(shí)間 線程池滿的時(shí)候的執(zhí)行策略绞幌。然后介紹了線程池的工作流程蕾哟,以及這幾個(gè)參數(shù)是如何配合流程工作的。(這問(wèn)題啊奄,為了面試也得專門看渐苏,穩(wěn))

7掀潮、線程池內(nèi)的線程出現(xiàn)錯(cuò)誤拋出來(lái)異常菇夸?線程池會(huì)如何處理?

答:移除銷毀該線程仪吧,重新創(chuàng)建一個(gè)新線程(這個(gè)不知道答的對(duì)不對(duì)庄新,小伙伴可以自己查一下)

8、了解jvm模型嗎薯鼠,那些區(qū)域是線程共享的那些是線程獨(dú)享择诈?

答:線程棧,本地方法棧出皇,程序計(jì)數(shù)器是獨(dú)占的 堆和元空間共享的羞芍。

9、知道oom嗎郊艘,發(fā)生oom如何排查荷科?

答:巴拉巴拉一大堆,說(shuō)的估計(jì)不準(zhǔn)確纱注,但是大概意思是這樣子的畏浆。

10、數(shù)據(jù)庫(kù)的隔離級(jí)別狞贱,什么是臟讀刻获,mysql默認(rèn)的隔離級(jí)別。

答:巴拉巴拉一堆瞎嬉,(基本概念題是蝎毡,穩(wěn)的一批)

11厚柳、做過(guò)sql優(yōu)化嗎 mysql 索引的數(shù)據(jù)結(jié)構(gòu) 什么時(shí)候索引會(huì)失效

? 答B(yǎng)+Tree 然后巴拉巴拉一大堆。

12沐兵、接著問(wèn)B+Tree有什么特點(diǎn)草娜,為什么要用B+樹(shù)

答 巴拉巴拉一大堆(做足了準(zhǔn)備,穩(wěn)的一批)痒筒。

13 介紹幾個(gè)設(shè)計(jì)模式宰闰?項(xiàng)目應(yīng)用

答:工程模式,模板方法模式簿透,策略模式移袍,責(zé)任鏈模式。

認(rèn)證鑒權(quán)管理用的責(zé)任鏈模式

一面大概40分鐘老充,主要記得的就上面這些問(wèn)題葡盗。

線程池用的策略模式

springmvc中用的適配器模式調(diào)用controller方法。(不一定介紹項(xiàng)目應(yīng)用啡浊,介紹源碼應(yīng)用也一樣的)


兩天之后二面(視頻面試)

1觅够、i++和++i;

2、equals和== 區(qū)別

3巷嚣、方法的重寫(xiě)和重載

(這三個(gè)問(wèn)題問(wèn)的我狂喜喘先,我四年工作經(jīng)驗(yàn)問(wèn)我這個(gè)?廷粒?窘拯?然后平靜的回答了這些問(wèn)題)

后面全程高能,不做面試準(zhǔn)備基本連話都說(shuō)不出來(lái)0泳ァ5渔ⅰ!嗤放!

4思喊、談一談synchronized知道它的膨脹升級(jí)過(guò)程嗎

答:每個(gè)對(duì)象都可以成為synchronized的鎖對(duì)象,在對(duì)象的對(duì)象頭存有持鎖線程的信息次酌。然后介紹了一下synchronized的無(wú)鎖->偏向鎖->輕量級(jí)鎖->重量級(jí)鎖的整個(gè)過(guò)程恨课,巴拉巴拉一大堆。

5和措、AQS了解嗎庄呈,知道AQS框架下的那些鎖,有看過(guò)源碼實(shí)現(xiàn)嗎

答:介紹了ReentrantLock?后面說(shuō)源碼實(shí)現(xiàn)隨便說(shuō)了說(shuō)派阱。(基本我已經(jīng)忘完了源碼诬留,答得比較爛)

6、redis用過(guò)嗎?它又那些數(shù)據(jù)類型文兑?你們項(xiàng)目中這么用的這些數(shù)據(jù)類型盒刚?

答巴拉巴拉一大堆(這個(gè)文體還好 ,我們主要用String 和hash?然后介紹了一些簡(jiǎn)單的業(yè)務(wù)場(chǎng)景使用)

7绿贞、了解redis的緩存淘汰機(jī)制嗎因块?遇到過(guò)redis內(nèi)存崩潰嗎?

答?

LRU算法然后介紹了一下算法實(shí)現(xiàn)籍铁。redis內(nèi)存崩潰沒(méi)遇到過(guò)(實(shí)在不敢說(shuō)遇到過(guò)涡上,萬(wàn)一接著這個(gè)問(wèn)題往下問(wèn),這么辦拒名。不敢接)吩愧。

8、看你簡(jiǎn)歷里面都是用的springBoot增显,如何做一個(gè)start

答:詳細(xì)說(shuō)明了一下如何做一個(gè)start(這個(gè)之前學(xué)springboot的時(shí)候做過(guò)雁佳,比較清楚),并介紹了一下自動(dòng)裝配原理

9同云、spring的bean聲明周期?

答:巴拉巴拉一大堆(終于輪到我發(fā)揮了糖权,我自認(rèn)為答的最好的一個(gè)問(wèn)題,從源碼層面將sping容器啟動(dòng)過(guò)程炸站,如何解決循環(huán)依賴星澳,為什么要用三級(jí)緩存,springAop

sping和mybatis整合和面試官深入探討一番武契,過(guò)程20分鐘募判,不磕不拌,接下面的問(wèn)題面試官再也沒(méi)提spring的事)

10咒唆、介紹一下啊mysql有那些引擎,有什么區(qū)別释液,mysql的鎖

答:巴拉巴拉一大堆(又是一大堆概念問(wèn)題全释,穩(wěn)穩(wěn)的)

11、用過(guò)分布式鎖嗎误债?這么實(shí)現(xiàn)分布式鎖的浸船?

答:用過(guò),redis做分布式鎖 介紹了一下redission框架和原理(這個(gè)最近項(xiàng)目中有用到這寝蹈,所以比較了解李命,總的來(lái)說(shuō),你要是用的現(xiàn)成框架實(shí)現(xiàn)的箫老,需要知道原理封字,如果你是自己寫(xiě)的,需要知道實(shí)現(xiàn)細(xì)節(jié)以及考慮了那些問(wèn)題)

12、看你用過(guò)rabbitmq阔籽,你們是在什么場(chǎng)景下用的流妻,你們是這么做可靠性投遞的?

答:介紹了我們的應(yīng)用場(chǎng)景笆制,已經(jīng)可靠性投遞的實(shí)現(xiàn)(消息重復(fù)發(fā)送和消費(fèi)者做冪等性保證)(說(shuō)實(shí)話感覺(jué)過(guò)于簡(jiǎn)單绅这,面試官?zèng)]有看上我們的方案)

13 dubbo 的服務(wù)暴露和注冊(cè)或稱,調(diào)用過(guò)程

答在辆;巴拉巴拉一堆(我簡(jiǎn)歷上寫(xiě)的有dubbo证薇,但是很久都沒(méi)有用了,如果不寫(xiě)匆篓,那簡(jiǎn)歷上一個(gè)rpc都沒(méi)有棕叫,有點(diǎn)磕磣,還是寫(xiě)了奕删,照著準(zhǔn)備的答一下吧)

14 什么是CAP理論俺泣?zookeeper是cp架構(gòu)還是ap架構(gòu)?為什么完残?

答:巴拉巴拉一大堆伏钠。(解釋一下:CPA是指 C:數(shù)據(jù)一致性 A:系統(tǒng)可用性 P:分區(qū)一致性 簡(jiǎn)單說(shuō):我們的服務(wù)如果是多節(jié)點(diǎn)集群部署,那么總會(huì)存在網(wǎng)絡(luò)等問(wèn)題造成節(jié)點(diǎn)之前無(wú)法通信問(wèn)題谨设,所以要保證P熟掂,在發(fā)生網(wǎng)絡(luò)不可達(dá)造成節(jié)點(diǎn)信息不一致是,要么你停止對(duì)外服務(wù)扎拣,保證數(shù)據(jù)一致性 這就是CP架構(gòu)赴肚,要么你繼續(xù)提供服務(wù),但是節(jié)點(diǎn)數(shù)據(jù)不一致二蓝,這就是AP架構(gòu)誉券,這個(gè)大家可以參考資料。之前沒(méi)了解過(guò)刊愚,為了面試準(zhǔn)備看到的踊跟。)

15 現(xiàn)在有10萬(wàn)電影票 如何實(shí)現(xiàn)秒殺搶電影票?

答:用分布式鎖鸥诽,然后巴拉巴拉將了一大堆(開(kāi)放性問(wèn)題商玫,只要你說(shuō)的有道理就行,但是不能不說(shuō))

16 數(shù)據(jù)庫(kù)里面的表有2000w數(shù)據(jù)牡借,如何處理拳昌?

答:(其實(shí)想問(wèn)如何分庫(kù)分表,委婉得表示了一下自己實(shí)際應(yīng)用中并沒(méi)有分庫(kù)分表得經(jīng)驗(yàn)钠龙。)

17 你用到過(guò)spingCloud沒(méi)有牵敷?

答:沒(méi)有。面試官應(yīng)該看我的簡(jiǎn)歷沒(méi)有springCloud酬荞,所以問(wèn)了一下,這里我簡(jiǎn)單得介紹了我們得項(xiàng)目情況畅买,沒(méi)有必要上springCloud然后表明了自己最近也在看springCloud并且向面試官介紹了幾個(gè)組件及其實(shí)現(xiàn)原理。

算法題:

給一個(gè)int數(shù)組包含重復(fù)元素细睡,如何統(tǒng)計(jì)不重復(fù)元素得個(gè)數(shù)谷羞,并且輸出不重復(fù)元素?

排序加雙指針?lè)?/p>

可以參考力扣題目?https://leetcode-cn.com/problems/remove-duplicates-from-sorted-array/?解法大同小易

因?yàn)樽鲞^(guò)這個(gè)上面力扣這道題溜徙,所以第一反應(yīng)就是有思路序加雙指針?lè)ǎ炻羔槪┐蟾?5分鐘做完湃缎,寫(xiě)代碼得時(shí)候會(huì)和面試官交流思路,然后因?yàn)榫o張蠢壹,變量名都寫(xiě)錯(cuò)了嗓违,面試官給了提示。還好最后運(yùn)行出來(lái)了图贸。

二面是所有時(shí)間最長(zhǎng)得一面蹂季,考察的也很廣,大概持續(xù)了一個(gè)多小時(shí)疏日。面試完整個(gè)人都虛脫了偿洁。

三面:(視頻面試)

聊了聊項(xiàng)目得實(shí)際情況,問(wèn)了一下項(xiàng)目某些功能得具體實(shí)現(xiàn)沟优,并問(wèn)了一下哪個(gè)項(xiàng)目最讓你感覺(jué)成功以及解決了那些問(wèn)題讓你印象深刻涕滋。

我回答了最近的項(xiàng)目,深度參與到了需求分析挠阁,代碼開(kāi)發(fā)宾肺,問(wèn)題修改,環(huán)境發(fā)布侵俗,技術(shù)文檔輸出锨用。然后舉了一個(gè)開(kāi)發(fā)遇到得數(shù)據(jù)庫(kù)死鎖問(wèn)題(加索引引起得select操作和update操作在并發(fā)條件下出現(xiàn)得死鎖,坡慌,以及排查和解決過(guò)程黔酥。)

由于項(xiàng)目是在沒(méi)有高并發(fā)和大數(shù)據(jù)得地方,面試官可能也沒(méi)覺(jué)得要問(wèn)得地方洪橘,最后讓寫(xiě)了一個(gè)排序算法,時(shí)間復(fù)雜度在O(nlogn)級(jí)別

(其實(shí)就是讓你在快排棵帽,堆排熄求,歸并排之前選一個(gè)寫(xiě)),我寫(xiě)了一個(gè)歸并排序逗概。并簡(jiǎn)單聊了一下分治得思想弟晚。

三面結(jié)束!!卿城!不到半個(gè)小時(shí)

后面隔了一天hr打電話說(shuō)面試通過(guò)枚钓,走offer發(fā)放流程。

總結(jié):基礎(chǔ)貫穿整個(gè)面試過(guò)程瑟押,所以復(fù)習(xí)基礎(chǔ)很重要搀捷,spring

mysql jvm 鎖 面試大廠必問(wèn)。另外我相信很多和我一樣一直在小公司開(kāi)發(fā)的程序員多望,項(xiàng)目根本就沒(méi)有高并發(fā)嫩舟,(有并發(fā),高并發(fā)談不上)大數(shù)據(jù)處理真實(shí)項(xiàng)目經(jīng)驗(yàn) 怀偷。都是一些業(yè)務(wù)項(xiàng)目家厌。這個(gè)時(shí)候簡(jiǎn)歷上面不建議寫(xiě)有高并發(fā)大數(shù)據(jù)處理項(xiàng)目經(jīng)驗(yàn)。如果你寫(xiě)了椎工,他會(huì)問(wèn)你哪個(gè)項(xiàng)目做的高并發(fā)饭于,是什么業(yè)務(wù),具體做了那些并發(fā)管理 并發(fā)量是多少维蒙,qps 多少掰吕,各種處理細(xì)節(jié),集群這么搭的等等一堆只有做過(guò)才能答上來(lái)的問(wèn)題木西。這部分不像基礎(chǔ)知識(shí)和源碼能靠自己學(xué)習(xí)就能搞定畴栖。萬(wàn)一被問(wèn)露餡了那更是給面試官留下一個(gè)非常不好的印象。你可以說(shuō)自己學(xué)習(xí)了解過(guò)這部分知識(shí)八千,也知道一些方案吗讶。可以和面試官講一下這些方案恋捆。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末照皆,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子沸停,更是在濱河造成了極大的恐慌膜毁,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,539評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件愤钾,死亡現(xiàn)場(chǎng)離奇詭異瘟滨,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)能颁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門杂瘸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人伙菊,你說(shuō)我怎么就攤上這事败玉〉型粒” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,871評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵运翼,是天一觀的道長(zhǎng)返干。 經(jīng)常有香客問(wèn)我,道長(zhǎng)血淌,這世上最難降的妖魔是什么矩欠? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,963評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮六剥,結(jié)果婚禮上晚顷,老公的妹妹穿的比我還像新娘。我一直安慰自己疗疟,他們只是感情好该默,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著策彤,像睡著了一般栓袖。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上店诗,一...
    開(kāi)封第一講書(shū)人閱讀 51,763評(píng)論 1 307
  • 那天裹刮,我揣著相機(jī)與錄音,去河邊找鬼庞瘸。 笑死捧弃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的擦囊。 我是一名探鬼主播违霞,決...
    沈念sama閱讀 40,468評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼瞬场!你這毒婦竟也來(lái)了买鸽?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤贯被,失蹤者是張志新(化名)和其女友劉穎眼五,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體彤灶,經(jīng)...
    沈念sama閱讀 45,850評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡看幼,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了幌陕。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片桌吃。...
    茶點(diǎn)故事閱讀 40,144評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖苞轿,靈堂內(nèi)的尸體忽然破棺而出茅诱,到底是詐尸還是另有隱情,我是刑警寧澤搬卒,帶...
    沈念sama閱讀 35,823評(píng)論 5 346
  • 正文 年R本政府宣布瑟俭,位于F島的核電站,受9級(jí)特大地震影響契邀,放射性物質(zhì)發(fā)生泄漏摆寄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評(píng)論 3 331
  • 文/蒙蒙 一坯门、第九天 我趴在偏房一處隱蔽的房頂上張望微饥。 院中可真熱鬧,春花似錦古戴、人聲如沸欠橘。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,026評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)肃续。三九已至,卻和暖如春叉袍,著一層夾襖步出監(jiān)牢的瞬間始锚,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,150評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工喳逛, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留瞧捌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,415評(píng)論 3 373
  • 正文 我出身青樓润文,卻偏偏與公主長(zhǎng)得像姐呐,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子转唉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容