作為一位二本畢業(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í)八千,也知道一些方案吗讶。可以和面試官講一下這些方案恋捆。