導(dǎo)讀:
架構(gòu)師應(yīng)不應(yīng)該寫代碼
為什么別人的系統(tǒng)總是那么爛
成為架構(gòu)師最困難的門檻是什么拼坎?
如何更高效的學(xué)習(xí)钾唬?
1.架構(gòu)師應(yīng)不應(yīng)該寫代碼
合格的程序員對于明確分配的任務(wù)會完成的很好虱肄,但是大部分情況下“架構(gòu)”這個詞意味著架構(gòu)師并不會涉及太多細節(jié)莉给,架構(gòu)圖和代碼實現(xiàn)之間總還是有些距離楷怒,你無法保證所有人都會正確的理解你的設(shè)計垛吗,或者是程序員寫代碼時遇到障礙時會立刻想出足夠優(yōu)雅的解決方案织堂。
在我看來叠艳,寫代碼的架構(gòu)師更像是在做后勤保障的工作:在代碼中第一時間發(fā)現(xiàn)可能存在的問題捧挺,向其他人提出警告虑绵,或是給予其他人改進的意見,必要的時候或是給其他人演示一下正確的姿勢翅睛。
大部分情況下我作為架構(gòu)師并不需要攬下“核心模塊”開發(fā)這種工作,畢竟我能調(diào)配的時間太零散了黑竞,效率難以保證捕发,很多人在專注的情況下比我做的好很多,我只需要保持大局觀需要適度參與就可以了很魂。
總的來說扎酷,架構(gòu)師和程序員在某些方面上有點像產(chǎn)品經(jīng)理和用戶的關(guān)系,大部分程序員并不會主動告訴你他們想要什么遏匆、哪里需要優(yōu)化法挨,甚至自己也不知道這些谁榜。想要做出好的產(chǎn)品,捷徑之一就是跟用戶做同樣的事情凡纳。
2.為什么別人的系統(tǒng)總是那么爛
很多程序員解決問題的能力很強窃植,說要解決一個什么問題,下午就能寫出幾百行代碼把功能實現(xiàn)了荐糜。但是做出來的東西有種少考慮了什么東西的感覺巷怜。大部分程序都能實現(xiàn)功能,但是如果把“時間”這個也作為一個考慮的維度的話暴氏,就會意識到一個合格的項目需要考慮更多的東西:更通用的使用方式延塑、易于理解的文檔、簡單而易于擴展的設(shè)計答渔,等等关带。
很多公司應(yīng)該都會有一些遺留系統(tǒng),它們龐大研儒、笨重豫缨、難用、幾乎無法維護端朵,所有人都在抱怨這些系統(tǒng),并且每天都在想方設(shè)法換掉那些遺留系統(tǒng)燃箭。但是一段時間過去之后冲呢,又會發(fā)現(xiàn)身邊的新人又開始吐槽當(dāng)時替代遺留系統(tǒng)的那個系統(tǒng)了。
“大多數(shù)系統(tǒng)當(dāng)初都很好使招狸,功能當(dāng)時夠用敬拓,擴展性看起來也可以,但是這些系統(tǒng)都是開發(fā)的人離職之后變壞的裙戏〕送梗”
3.成為架構(gòu)師最困難的門檻是什么?
很多人自稱架構(gòu)師的人跟你講一個架構(gòu)時簡直滔滔不絕累榜,各種技術(shù)名詞像是說相聲一樣從他嘴里說出來营勤,三句話不離高并發(fā)大數(shù)據(jù),但是稍微追問一下壹罚,就會發(fā)現(xiàn)很多基本概念的缺失葛作,例如自稱精通高并發(fā)的人說不清楚他所謂的高并發(fā)系統(tǒng)的瓶頸在哪里,自稱精通架構(gòu)設(shè)計的人說不明白他的系統(tǒng)怎么保證高可用猖凛,自稱超大數(shù)據(jù)量的系統(tǒng)實際上只有不到100萬條數(shù)據(jù)赂蠢,等等。
架構(gòu)師雖然聽起來很高大上辨泳,但本質(zhì)上仍然是工程師虱岂,不是科學(xué)家玖院,也不是忽悠人的江湖騙子。學(xué)習(xí)再多第岖,也需要實踐落地难菌。設(shè)計架構(gòu)方案更多的是在做一些抽象和權(quán)衡:把復(fù)雜的需求抽象成簡單的模型,從功能绍傲、性能扔傅、可用性、研發(fā)成本等等方面規(guī)劃如何構(gòu)建一個系統(tǒng)烫饼,這些內(nèi)容需要更多的實踐練習(xí)猎塞。
4.如何更高效的學(xué)習(xí)?
大多數(shù)人每天能留給自己學(xué)習(xí)的時間有限杠纵,這個階段如何提升學(xué)習(xí)效率就成了要解決的重點荠耽。
說說自己提升學(xué)習(xí)效率的心得,其實非常簡單:體系化的學(xué)習(xí)比藻。
在重復(fù)了幾次痛苦的學(xué)習(xí)-梳理過程后铝量,再去看一些獨立的文章或者資料往往會事半功倍,因為能在體系內(nèi)找到相對應(yīng)的知識银亲,甚至有時候一本書里一頁只需要看一句話慢叨,點破那層窗戶紙,就可以掌握新的知識务蝠。
跟很多人一樣拍谐,剛畢業(yè)時我覺得作為程序員,只要努力馏段,加上少許天賦便可以獲得一些成績轩拨。
工作一段時間后,對自己和其他人的認識也越來越清晰院喜,逐漸的發(fā)現(xiàn)程序員之間的差距或許比人和猴子之間的差距還大亡蓉,接受這個事實這讓我郁悶了很久。
再過一段時間喷舀,發(fā)現(xiàn)自己已經(jīng)能夠客觀的評價自己的能力砍濒,也意識到了距離并不是那么重要,只要想辦法跑的更快元咙,就足夠了梯影。
5.快速成為架構(gòu)師的學(xué)習(xí)路線
以下五大知識體系是我從業(yè)多年總結(jié)出來的經(jīng)驗,都是當(dāng)前最主流的技術(shù)庶香。想學(xué)習(xí)這些技術(shù)的朋友可以加群:619881427甲棍。群里會分享這些技術(shù)知識點供大家學(xué)習(xí)免費下載
分布式學(xué)習(xí)路線
微服務(wù)學(xué)習(xí)路線
性能優(yōu)化學(xué)習(xí)路線
經(jīng)典設(shè)計模式與源碼分析
開發(fā)必備工具
動手實踐項目
以上五大知識體系是我從業(yè)多年總結(jié)出來的經(jīng)驗苟径,都是當(dāng)前最主流的技術(shù)共螺。想學(xué)習(xí)這些技術(shù)的朋友可以加群:619881427。群里會分享這些技術(shù)知識點供大家學(xué)習(xí)免費下載