58同城2017研發(fā)面試題
58同城 2017研發(fā)一面面試來(lái)臨了,你準(zhǔn)備好了嗎?面試時(shí)不要緊張,下面就由學(xué)習(xí)啦小編為大家介紹一下58同城2017研發(fā)面試題的文章,歡迎閱讀。
58同城2017研發(fā)面試題篇1
1.手寫(xiě)KMP算法
我猜測(cè)考這道題并不是真的要被面者把KMP算法一字不漏的寫(xiě)出來(lái)(當(dāng)然能寫(xiě)出來(lái)最好),面試官一上來(lái)就出一道很難的題可能有兩點(diǎn)用意:
1)看看被面者心理承受能力,是說(shuō)道KMP就跪地求饒呢還是拼死拼活寫(xiě)點(diǎn)算點(diǎn)?心態(tài)很重要,顯然后者更好
2)寫(xiě)出代碼了,看看被面者的代碼風(fēng)格怎么樣?有沒(méi)有把代碼寫(xiě)得很魯棒?有沒(méi)有考慮到邊界?有沒(méi)有用簡(jiǎn)潔易懂的變量名?
2.0.線程和進(jìn)程的區(qū)別
1)進(jìn)程是CPU分配資源的最小單位,線程是CPU調(diào)度的最小單位
2)進(jìn)程之間是獨(dú)立的,每個(gè)進(jìn)程獨(dú)享資源(如內(nèi)存空間),而線程間是共享內(nèi)存(除了棧以及寄存器外)。因此在線程間可以直接互相通行(直接訪問(wèn)同一塊內(nèi)存),而進(jìn)程之間需要特殊手段,例如管道、消息隊(duì)列、共享內(nèi)存、信號(hào),socket等
3)線程是輕量級(jí)的進(jìn)程,開(kāi)銷(xiāo)通常要比進(jìn)程小,因此能用線程的地方盡量用線程。
4)一個(gè)進(jìn)程至少擁有一個(gè)線程,即主線程(Main Thread)
2.1既然線程比進(jìn)程開(kāi)銷(xiāo)要小,那具體小在哪里?
線程的開(kāi)銷(xiāo)是明顯小于進(jìn)程開(kāi)銷(xiāo)的,主要體現(xiàn)在創(chuàng)建和上下文切換的時(shí)候。我在一本書(shū)上看到,Solaris 2中 進(jìn)程的創(chuàng)建要比線程創(chuàng)建慢30倍 ,進(jìn)程切換要比線程切換慢5倍。那么,為什么進(jìn)程和線程的效率差別如此之大呢?
1)資源開(kāi)銷(xiāo):操作系統(tǒng)每創(chuàng)建一個(gè)進(jìn)程,就要為之分配一筆很大的資源,比如I/O,內(nèi)存等,而每個(gè)線程所占用的資源要比進(jìn)程小得多。通常線程自己只需要獨(dú)立的棧空間和寄存器空間就可以了,其他資源都和其他兄弟線程共享。因此在創(chuàng)建的時(shí)候,進(jìn)程要比線程慢得多
2)操作系統(tǒng)的管理:每個(gè)進(jìn)程有一個(gè)PCB,每一個(gè)線程有個(gè)TCB,分別記錄的都是進(jìn)程和線程的當(dāng)前狀態(tài)。但是,PCB要比TCB大得多,是一個(gè)龐大的結(jié)構(gòu)體(struct),在進(jìn)程切換時(shí),涉及到整個(gè)當(dāng)前進(jìn)程環(huán)境的保存環(huán)境的設(shè)置以及新被調(diào)度運(yùn)行的環(huán)境的設(shè)置(即先將當(dāng)前進(jìn)程的狀態(tài)保存到自己的PCB中,再用新進(jìn)程的PCB初始化當(dāng)前運(yùn)行環(huán)境),而線程切換只需保存和設(shè)置少量的寄存器的內(nèi)容(也是保存在TCB中)
2.2哪些情況下必須要用進(jìn)程?
我們說(shuō)過(guò),在能用線程的地方盡量用線程,因?yàn)榫€程無(wú)論在資源占有還是效率上都優(yōu)于進(jìn)程。但是,進(jìn)程的存在,也是有其必要的。下面就談?wù)勈裁磿r(shí)候用線程更恰當(dāng),什么時(shí)候用進(jìn)程更恰當(dāng)。其理論依據(jù),還是在線程和進(jìn)程本身的特點(diǎn)和區(qū)別。
1)需要頻繁創(chuàng)建銷(xiāo)毀的優(yōu)先用線程
原因請(qǐng)看上面的對(duì)比。
這種原則最常見(jiàn)的應(yīng)用就是Web服務(wù)器了,來(lái)一個(gè)連接建立一個(gè)線程,斷了就銷(xiāo)毀線程,要是用進(jìn)程,創(chuàng)建和銷(xiāo)毀的代價(jià)是很難承受的
2)需要進(jìn)行大量計(jì)算的優(yōu)先使用線程
所謂大量計(jì)算,當(dāng)然就是要耗費(fèi)很多CPU,切換頻繁了,這種情況下線程是最合適的。
這種原則最常見(jiàn)的是圖像處理、算法處理。
3)強(qiáng)相關(guān)的處理用線程,弱相關(guān)的處理用進(jìn)程
什么叫強(qiáng)相關(guān)、弱相關(guān)?理論上很難定義,給個(gè)簡(jiǎn)單的例子就明白了。
一般的Server需要完成如下任務(wù):消息收發(fā)、消息處理。“消息收發(fā)”和“消息處理”就是弱相關(guān)的任務(wù),而“消息處理”里面可能又分為“消息解碼”、“業(yè)務(wù)處理”,這兩個(gè)任務(wù)相對(duì)來(lái)說(shuō)相關(guān)性就要強(qiáng)多了。因此“消息收發(fā)”和“消息處理”可以分進(jìn)程設(shè)計(jì),“消息解碼”、“業(yè)務(wù)處理”可以分線程設(shè)計(jì)。
當(dāng)然這種劃分方式不是一成不變的,也可以根據(jù)實(shí)際情況進(jìn)行調(diào)整。
個(gè)人理解:強(qiáng)相關(guān)涉及到兩個(gè)工作任務(wù)之間的強(qiáng)依賴(lài),如頻繁交換信息;弱相關(guān)就是兩個(gè)工作任務(wù)間幾乎沒(méi)有交流,各自獨(dú)立工作。
4)可能要擴(kuò)展到多機(jī)分布的用進(jìn)程,多核分布的用線程
5)都滿足需求的情況下,用你最熟悉、最拿手的方式
至于“數(shù)據(jù)共享、同步”、“編程、調(diào)試”、“可靠性”這幾個(gè)維度的所謂的“復(fù)雜、簡(jiǎn)單”應(yīng)該怎么取舍,我只能說(shuō):沒(méi)有明確的選擇方法。但我可以告訴你一個(gè)選擇原則:如果多進(jìn)程和多線程都能夠滿足要求,那么選擇你最熟悉、最拿手的那個(gè)。
需要提醒的是:雖然我給了這么多的選擇原則,但實(shí)際應(yīng)用中基本上都是“進(jìn)程+線程”的結(jié)合方式,千萬(wàn)不要真的陷入一種非此即彼的誤區(qū)。
58同城2017研發(fā)面試題篇2
1.0.http怎么傳輸數(shù)據(jù)的?
1.1.http長(zhǎng)連接和短連接的區(qū)別以及使用時(shí)機(jī)
http://blog.csdn.net/yankai0219/article/details/8208776
2.C#怎么管理內(nèi)存的?
58同城2017研發(fā)面試題篇3
如果你需要你的上司給你寫(xiě)一個(gè)模塊,兩天之后你要用到,但是上司要在第三天才給你,導(dǎo)致你的工期延誤,你會(huì)怎么做?
補(bǔ)充:今天收到58給的offer,薪資還算給力。總結(jié)了一下成功的原因,發(fā)現(xiàn)還是有很多技巧的。實(shí)力肯定必須擺在首位。但是,面試的成功不僅僅靠實(shí)力說(shuō)話,成功的標(biāo)準(zhǔn)是“通過(guò)這幾十分鐘的溝通,結(jié)束之后面試官是否樂(lè)意今后與你共事。如果他感覺(jué)很好,面試就成功了;如果他覺(jué)得以后不想和你相處,面試就失敗了。”因此,博得面試官的好感大于把每一道題都準(zhǔn)確無(wú)誤地“背”出來(lái)。經(jīng)過(guò)這么多長(zhǎng)面試,我覺(jué)得面試時(shí)注意以下幾點(diǎn):
1)多和面試官交流想法而不是“他問(wèn)你答”的刻板面試。
2)代碼的風(fēng)格(變量命名規(guī)則,縮進(jìn),函數(shù)命名,代碼整潔度,魯棒性等)大于代碼的正確性,因?yàn)槟愕拇a他能力再高也不會(huì)在很短的時(shí)間內(nèi)讀的很透徹,大部分精力應(yīng)該就放在風(fēng)格和邊界值等上了。但是,也不能犯那種重大的邏輯錯(cuò)誤(只要面試官憑感覺(jué)看不出來(lái)就可以了)。
3)說(shuō)臟話在一定程度上會(huì)起到良好的效果。但是,要有個(gè)度!偶爾一句“TMD”“坑爹”“這道題最蛋疼了...”"XXX代碼寫(xiě)得亂七八糟的..."等有助于打破“很正規(guī)”的面試氣氛。更平等地交流。(PS:你和你的同學(xué)、同事說(shuō)話不會(huì)有任何拘束吧,把面試官就看成你的同學(xué)或同事)
4)當(dāng)遇到不會(huì)的題或不明白的知識(shí)點(diǎn),又需要表現(xiàn)的十分謙虛和好學(xué)。勇敢地把你不清楚的說(shuō)出來(lái)和面試官交流討論而不是忽略過(guò)去避而不談。比如可以說(shuō)“我在很多地方都見(jiàn)到多這道題但是一直沒(méi)有找到一個(gè)滿意的答案,您能給我講講思路么?”或者說(shuō)“我感覺(jué)這道題可以用XXX方法做,而且時(shí)間復(fù)雜度還不錯(cuò),但是具體的思路還沒(méi)有想透徹!”
5)當(dāng)面是官甩給你一道題后你感覺(jué)可以用O(n)的時(shí)間復(fù)雜度完成但是僅僅找到了O(n^2)的解法,這是不妨這么說(shuō)“我曾經(jīng)記得有個(gè)O(n)時(shí)間復(fù)雜度的解法,但是現(xiàn)在只想到了一個(gè)O(n^2)的解法,不妨我說(shuō)一下思路吧,您看看還有什么改進(jìn)的地方?jīng)]。”然后補(bǔ)充道“其實(shí)有時(shí)候過(guò)分關(guān)注算法的時(shí)間復(fù)雜度并不是好的軟件工程思想,很多時(shí)候花了大部分精力優(yōu)化的地方并不是性能的瓶頸,還不如一個(gè)復(fù)雜度稍差但清晰易懂的算法呢!”
6)加分點(diǎn):你的技術(shù)博客、平時(shí)看的書(shū)、經(jīng)常瀏覽的論壇、參加的項(xiàng)目、關(guān)注的最新技術(shù)(哪怕只能說(shuō)出皮毛)、崇拜的偶像(當(dāng)然是IT行業(yè)的,周潤(rùn)發(fā)什么的就別說(shuō)了)、新奇的想法等。在面試的過(guò)程中盡可能抖出來(lái),比如說(shuō)“我在XXX論壇上看見(jiàn)他們是這么討論這個(gè)問(wèn)題的.....”比“我覺(jué)得是這個(gè)問(wèn)題應(yīng)該這樣解決....”要好。總之,盡量在交流中把這些點(diǎn)說(shuō)出來(lái)