1.項(xiàng)目開(kāi)發(fā),你考慮了什么遏佣?
2.算法只是實(shí)現(xiàn)就行了挖炬?
3.設(shè)計(jì)模式為什么重要?
最近在面試和復(fù)習(xí)中状婶,有些感悟意敛,便分享給大家。
肯定有很多小伙伴們都是計(jì)算機(jī)相關(guān)的膛虫,而我自身也是計(jì)算機(jī)軟件方面的草姻,而經(jīng)過(guò)這大概一個(gè)月的時(shí)間,通過(guò)面試和復(fù)習(xí)稍刀,帶給我的感受還是蠻多的撩独,這里我不想說(shuō)那些學(xué)習(xí)的東西,而是想表達(dá)一點(diǎn)账月,帶著思考去學(xué)習(xí)综膀。
項(xiàng)目開(kāi)發(fā),你考慮了什么局齿?
?在上周面試的時(shí)候剧劝,一個(gè)老哥看了我的簡(jiǎn)歷。
老哥:小伙子做過(guò)項(xiàng)目是吧抓歼,我看你這寫(xiě)了負(fù)責(zé)登錄讥此,那你說(shuō)說(shuō)你們登錄是怎么弄的示绊。
我:我便說(shuō)用戶(hù)登錄,將賬號(hào)密碼進(jìn)行比對(duì)暂论,如果有面褐,那么就返回確認(rèn)登錄,如果沒(méi)有取胎,就不讓登錄展哭。
老哥:除了這些呢?
我:進(jìn)行了權(quán)限校驗(yàn)闻蛀,去進(jìn)行判斷是否具有權(quán)限訪(fǎng)問(wèn)匪傍。比如會(huì)員登錄,或者普通用戶(hù)登錄觉痛。
老哥:那還有呢役衡?
我:進(jìn)行了優(yōu)化,比如當(dāng)前用戶(hù)如果沒(méi)有薪棒,傳入數(shù)據(jù)庫(kù)數(shù)據(jù)檢查是十分耗性能手蝎,那么我們進(jìn)行了優(yōu)化,采用Redis的布隆過(guò)濾器俐芯。
我們會(huì)發(fā)現(xiàn)棵介,一個(gè)功能的產(chǎn)生,需要很多地方去思考吧史,權(quán)限邮辽,安全,性能方面的考慮贸营,如果只是單純的實(shí)現(xiàn)賬號(hào)密碼匹配吨述,對(duì)自己的個(gè)人成長(zhǎng)也是沒(méi)有多少好處的,這里我想說(shuō)钞脂,多思考揣云,帶著問(wèn)題去設(shè)計(jì),而不是直接開(kāi)干芳肌。
算法
這個(gè)是我今天做程序員算法經(jīng)典題時(shí)看一個(gè)老哥的見(jiàn)解灵再,如果我是面試官,我會(huì)怎么問(wèn)亿笤?
實(shí)現(xiàn)一個(gè)算法,確定一個(gè)字符串 s 的所有字符是否全都不同栋猖。
示例 1:
輸入: s = "leetcode"
輸出: false
示例 2:
輸入: s = "abc"
輸出: true
限制:
0 <= len(s) <= 100
如果你不使用額外的數(shù)據(jù)結(jié)構(gòu)净薛,會(huì)很加分。
這個(gè)題其實(shí)很簡(jiǎn)單蒲拉,那么我們來(lái)看老哥以面試官的角度怎么看待問(wèn)題肃拜。
如果我是面試官痴腌,我會(huì)希望看到什么?
可能有點(diǎn)偏題燃领,畢竟這里主要就是做題的地方士聪。。
如果我是面試官猛蔽,會(huì)考慮主要考察什么剥悟,就我的工作經(jīng)驗(yàn)看,大多數(shù)主要是招聘工程師的曼库,面試者如果什么問(wèn)題都沒(méi)有区岗,直接寫(xiě)個(gè)二重循環(huán)搞定,會(huì)首先給個(gè)50分毁枯,如果能寫(xiě)點(diǎn)判斷字符串是否為null的慈缔,60分。
直接上手什么bitset种玛,什么位運(yùn)算的藐鹤,我會(huì)先問(wèn)他,題目中有沒(méi)有交代字符串的字符一定是26個(gè)英文字母赂韵?如果是unicode環(huán)境教藻,你是不是要準(zhǔn)備2^16/8個(gè)字節(jié)的空間?在實(shí)際項(xiàng)目中右锨,風(fēng)險(xiǎn)可控括堤,結(jié)果可期更重要,絕大多數(shù)時(shí)候不在乎那點(diǎn)時(shí)間和資源绍移。
所以我期望面試者不要急于解答悄窃,我希望他先問(wèn)我問(wèn)題:
字符串的字符范圍,如果我告訴他蹂窖,26個(gè)小寫(xiě)英文字母轧抗,那可能一開(kāi)頭直接判斷如果字符長(zhǎng)度>26, 直接返回False,做到這一點(diǎn)的瞬测,80分
如果我告訴他ascii字符集横媚,然后他的代碼里有邊界檢查,并且針對(duì)不同的范圍有不同的側(cè)重點(diǎn)月趟,比如說(shuō)ascii字符集灯蝴,那也就是128個(gè)可能性,16個(gè)字節(jié)的位運(yùn)算比較好
如果我告訴他是unicode孝宗,沒(méi)有字符范圍穷躁,老老實(shí)實(shí)排序再判斷是比較符合我對(duì)工程師的要求的,因?yàn)樗惴ㄐ阅芊€(wěn)定因妇,沒(méi)有額外資源要求问潭,一眼看出沒(méi)什么不可預(yù)見(jiàn)的風(fēng)險(xiǎn)猿诸,100分。
就是說(shuō)狡忙,有些東西梳虽,沒(méi)想到或者一時(shí)沒(méi)想到根本不是問(wèn)題,日常工作中稍微提示一下即可灾茁,但是縝密的思維對(duì)于程序員來(lái)說(shuō)更重要窜觉。
所以,對(duì)于算法删顶,我們不是說(shuō)實(shí)現(xiàn)了就可以竖螃,而是要多去判斷,多去思考逗余,分不同的情況考慮特咆。
設(shè)計(jì)模式
設(shè)計(jì)模式自我感覺(jué)在實(shí)際開(kāi)發(fā)中的用處還是很大的,因?yàn)檫@也是前人經(jīng)過(guò)大量的應(yīng)用實(shí)戰(zhàn)录粱,總結(jié)經(jīng)驗(yàn)腻格,使得我們?cè)陂_(kāi)發(fā)的時(shí)候,避開(kāi)一些彎路啥繁,錯(cuò)路菜职,使得開(kāi)發(fā)效率提升。而不僅僅是使得代碼的耦合一堆旗闽,不好維護(hù)不好管理酬核。
雖然腦子里想了很多,但發(fā)現(xiàn)其實(shí)總結(jié)下來(lái)也就幾句話(huà)适室,多帶著問(wèn)題思考嫡意,多想多問(wèn),追求性能捣辆,分多個(gè)場(chǎng)景考慮蔬螟。如果我們只是一味的完成任務(wù),那么很可能對(duì)自己的成長(zhǎng)并沒(méi)有那么的大汽畴,這也是送給今后的我旧巾,希望能在日常中多思考,而不只停留在簡(jiǎn)單的完成忍些。