1. 程式人生 > >15年資深架構師總結的經驗

15年資深架構師總結的經驗

我和很多人交流過一個有趣的現象,那就是剛畢業到30歲這段時間,會覺得時間過得很慢,總覺得自己還很年輕,但是一旦過了30歲,時間就如白駒過隙,一年又一年飛逝而過。

我自己也是,眼瞅著畢業快15年了,15年間從一個剛畢業的菜鳥,成長為技術骨幹,做到架構師的職位,回頭看看,當年聽取親戚的一句話,誤入計算機行業,看來並沒有走錯,程式設計雖然枯燥辛苦,但是如果真的感興趣,你就能體會到其中的樂趣,並且獲得可觀的回報。

1 好奇心

劉慈欣在《朝聞道》中描繪過這麼一個情節:在古老的非洲大陸上,有個原始人無意中擡頭仰望星空,凝視的時間稍微長了一些,超過了外星人設定的閾值,立刻拉響了人類即將產生文明的警報。因為外星人認為,人類已經產生了對宇宙的好奇心,文明的產生,科技的發展不過是一瞬間的事情。

確實是這樣,好奇心驅動人類不斷向前,在短短的幾千年(相對於長達幾十萬年的原始時代)裡就登上了月球,並且努力向其他行星拓展。

對於程式設計師來說也是類似,如果你看到新技術,新產品沒有像小孩看到新玩具那樣兩眼放光,沒有想趕緊在自己電腦上玩玩的衝動,你就需要仔細考慮下是否真的對軟體開發有興趣?如果根本沒興趣,不要浪費時間,還是趁早轉行,有更多有前(錢)途的職業在等著你。

沒有好奇心,就不願意追本溯源,追求技術的本質。

沒有好奇心,就難於靜下心來,耐得住寂寞,遠離浮躁和程式碼奮鬥,更難於跨過這個苦逼行業帶來的種種挑戰,走到架構師這個位置了。

沒有好奇心,就不願意學習新技術,一個架構師,如果沒有對技術的敏感度和前瞻性,一直抱著一套技術架構不變,估計很快會被淘汰。

當然自制力強大的人除外,但話說回來,靠著自制力讓自己做自己不喜歡的事情,豈不非常痛苦?

我在上公司的一個關於Leader的培訓課的時候,老師一直在說Passion(激情),Passion,Passion,但我一直覺得沒有好奇心,沒有興趣,怎麼會產生Passion呢?

所以,對技術的好奇心/興趣,是一切的基礎。

2 養成計算機的思維方式

之前在“碼農翻身”公共號發過一篇文章,叫《學會程式設計,而不是學會Java》說的就是要能夠以計算機的方式去思考。

現在的計算機還很“弱智”,你不能這麼說:『電腦,我要建立一個像Java的ArrayList類似的類,有個get、add、remove方法,還有這個ArrayList的容量不是固定的,能夠自增長,快點給我寫出來!』

現在的電腦當然寫不出來。

相反你只能用計算機能理解的方式,用非常非常低階的計算機語言去告訴它做事情:建立一個類,分配一個固定大小的陣列用來存放資料,用一個數(size)來記錄數組裡存了多少資料。如果陣列滿了,就需要增大陣列,並且把資料從老陣列複製到新陣列。

這裡邊有很多很多的煩人的細節需要你去處理,一不留神就會出錯—計算機程式設計就是這樣。

養成計算機的思維方式,流暢的把人類語言的需求轉化成計算機語言,這是程式設計師的基本功。

很多人會語法,也懂框架,但是在基本功上卻不過關,只能在初級程式設計師上踏步。

這個基本功的訓練就是資料結構和演算法,我的經驗是多做習題(大學時我把資料結構後面的習題都做了一遍),讓這個思維在腦子裡固化,以後的程式設計就可以信手拈來了。

3 紮實基礎,融會貫通

我很久之前參與過一點開源軟體的開發,有幸看到了一個老程式設計師的簡歷,讓我震驚的是他竟然在Altair這個最早的電腦上編過程式。

沒錯,Altair就是那個連顯示器和鍵盤都沒有,靠撥動開關來輸入,靠指示燈來輸出的所謂“個人電腦”,比爾蓋茨和保羅艾倫在上面寫了一個Baisc的直譯器,從此開始微軟之路。

如果有了在這樣的機器上程式設計的經歷,我相信這些老程式設計師對硬體,驅動,作業系統,應用軟體的理解要遠遠超過我們現在這些人。

我之前要寫文章遇到了一個問題:一個程序要讀取檔案,在底層用的是DMA的方式,DMA完成檔案讀取以後要通過中斷讓CPU去處理,但是CPU和中斷處理程式根本不知道程序的ID,它怎麼去和進行關聯,如何去喚醒那個等待的程序?這個問題讓我意識到其實我對計算機的基礎也並沒有融匯貫通。

我們大學裡都學過計算機組成原理、作業系統、編譯原理、計算機網路、資料庫、組合語言,能不能把這些知識融會貫通,打通任督二脈,在我們的腦海裡建立一個計算機運算的圖景?

把這些知識融為一體,我相信能超越絕大多數程式設計師。

現在的軟體開發封裝的層次已經非常高了,只要學會Java就能做一個程式設計工作了,隨著你做的越來越深,越來越專,這些基礎的問題就會浮現出來。

更重要的是,計算機軟硬體的基本思想在這幾十年裡其實變化不大,例如快取,增加抽象層等,有了這麼基本的思想的武裝,去學習新的東西不但學的快,理解的會更透徹。

4 要透徹地理解一個技術的本質

先舉個Ant中的例子,大部分人學習Ant只是學會怎麼使用,認識到Ant提供了很多內建的task來幫助我們方便的完成自動化的構建,例如命令。

<copytodir=”../backup/dir”>

<filesetdir=”src_dir”/>

<filterset>

<filtertoken=”TITLE”value=”FooBar”/>

</filterset>

</copy>

很少人會思考為什麼Ant的task是以XML來描述的?為什麼Ant不提供一套Java類庫/API來讓程式設計師用,那樣不是更自然嗎?

這其中的一個重要原因就是XML可以自定義標籤,所以表達力無與倫比;如果用java,它的語法不允許自定義一個像copy、fileset這樣的關鍵字,只能定義一些類來模擬這些Copy、Fileset,就沒有這麼簡單明瞭,不信你嘗試一下。

Ant給我們的重要啟示就是,用XML來描述任務,能極大的擴充套件語言的能力。但是Ant的問題就是需要程式設計師處理太多的細節,指定原始碼路徑,指定編譯檔案的路徑,指定資原始檔的路徑,指定需要的jar包及其位置,很煩心。

於是Maven出來使用“約定優於配置”的方式解決了Ant的問題。

理解了技術的本質以後就能夠觸類旁通,就能夠快速學習,這在技術更新很快的軟體行業尤為重要。

只是學會使用是不行的,不但要知道how,還要知道why。

停下來,思考,才是進步的本質。

5 要能寫漂亮的程式碼

架構師不是高高在上,脫離程式碼只說不做的人。架構師首先是一個優秀的程式設計師,要能夠編寫專案或產品中的核心功能,隨時能夠捲起袖子去解決專案中的問題。

程式碼寫的不漂亮怎麼能拿得出手?怎麼能夠服人?

所謂漂亮程式碼不僅僅是清晰、易懂、優雅,更要實現功能,沒有Bug或者極少Bug。

其實如果程式碼簡單優雅,一般沒什麼問題。

寫出漂亮程式碼並不容易,需要思路清晰,有良好的程式設計基礎,有優秀的抽象能力,以及對一門語言的熟練掌握。

6 抽象的能力

抽象思考的能力怎麼強調都不為過。

現實的需求紛繁複雜,如果架構師不能夠把這些亂無頭緒的需求抽象成一些“概念”,在概念的層次進行思考,系統根本就無法設計。

但是抽象出概念以後還不夠,還要看看這個概念是不是正交的,能不能獨立變化,如果不能,考慮下新的概念抽象。

“正交”講的是線性無關,非常重要,就像一個點(x,y),在x軸的變化不會影響y,y軸的變化不會影響x,這就是正交。

“正交”威力巨大,(x,y)可以表達二維平面的所有的點,如果增加一個z軸,不但能表達三維空間中所有的點,並且每個軸都可以獨立變化。

如果能做出正交的設計,這個系統的開發和維護會非常舒服,以為可以放心大膽的修改其中一個方面兒不會影響其他。

設計模式一直強調的『發現變化並且封裝變化』其實就是這個意思。

抽象能力的訓練沒有捷徑,就是經驗的積累,勤于思考和學習。例如:學習Android的程式設計師可以思考下Android是怎麼對未知的,紛繁複雜的應用程式進行抽象的?為什麼有Activity、Service、BroadcastReceiver、ContentProvider這四大元件?

7 技術領導力

我在IBM學到的重要一課就是:要用技術的影響力來領導人,而不是威權和職位。

換句大白話來說,就是要能讓技術人員服你。有了技術影響力,你在團隊發出的聲音才會被傾聽,被尊重。

但是影響力不是很快就建成的,這是個漫長的過程:你解決了一個技術難題,你提出的方案被證明可行….

這樣的事情會一點一滴的積累起你在別人心目中的形象,建立你的個人品牌,最終大家會給你貼上一個標籤:大牛。

作者:劉欣,15年的軟體行業從業經驗,曾任IBM高階系統架構師,擅長企業應用架構和設計,參與並且領導過多個企業級應用的設計和開發工作,IBM敏捷軟體開發專家,曾經給多家公司企業做敏捷諮詢和培訓服務。

文章轉自:http://www.jiagoushuo.com/article/1000468.html?utm_source=tuicool&utm_medium=referral

相關推薦

15資深架構總結經驗

我和很多人交流過一個有趣的現象,那就是剛畢業到30歲這段時間,會覺得時間過得很慢,總覺得自己還很年輕,但是一旦過了30歲,時間就如白駒過隙,一年又一年飛逝而過。 我自己也是,眼瞅著畢業快15年了,15年間從一個剛畢業的菜鳥,成長為技術骨幹,做到架構師的職位,回頭看看,當

15資深架構詳解:一個大型互聯網公司的微服務轉型實踐

微服務 架構 單片服務 微服務是一個比較大的話題,基於我的過往經歷,本文將以 Netflix 為例,分享一個大型互聯網公司如何從一個 Monolithic 的 APP 成功轉型到微服務。文章主要涉及微服務的產生歷史,應用場景,與單片服務區別,微服務帶來的技術、企業組織結構等方面挑戰,以及如何合

資深架構經驗分享——軟件項目開發和決策

oracl 標準庫 可能性 scrip 而不是 轉換 linu 質量保證 strong 這篇文章是關於什麽的 參與項目決策的人必須意識到他們的決定對項目的成功和成本以及時間和金錢的影響。 對於我20多年的軟件開發經驗和10多年的咨詢工作,我作為架構師或開發人員參與了許多項目

資深架構告訴Java程式設計師成為架構必須要掌握的知識點

分散式架構是 分散式計算技術的應用和工具,目前成熟的技術包括J2EE, CORBA和.NET(DCOM),這些技術牽扯的內容非常廣,並不是一兩句話就能說清楚的。因此想了解分散式知識點的可以關注我的VX公眾號:“Java架構師學習”。或者進群:688583154獲取免費的視訊錄影學習:Java工程化、高效能及

工作8的大資料架構經驗總結:大資料平臺選型及相關技術應用 11 個難點解讀

Q1、傳統數倉轉向大資料平臺的必要性? 如題,或者什麼場景的的傳統數倉適合轉向大資料平臺。轉向大資料平臺後都解決了什麼樣的問題,暴露出什麼樣的問題? A: ■ rein07 某證券 系統架構師: 大資料平臺採用分散式架構,用於解決海量資料的儲存和分析問題,傳統數倉無法解決上

企業資深架構,月薪幾十萬的技術大牛,總結的七條經驗

程式設計雖然苦,但有興趣就會有樂趣。把簡單的事情做到極致,回報自然就來了。朝聞道,夕死可矣。——尼古拉斯·小Q我和很多人交流過一個有趣的現象,那就是剛畢業到30歲這段時間,會覺得時間過得很慢,總覺得自己還很年輕,但是一旦過了30歲,時間就如白駒過隙,一年又一年飛逝而過。1.好

一名工作8的Java架構分享經驗之如何成為一名架構

Java高級很多工作一定年限的程序員感覺自己到了瓶頸不知道怎麽去突破,其實這個時候就要沖破傳說中的架構師。 架構師是個很神秘人物,那麽架構師的技術一般在什麽程度呢?怎樣才能被稱為架構師? 技術深度 有沒有看過JDK源碼,看過的類實現原理是什麽。 HTTP協議 TCP協議 一致性Hash算法 JVM如何加載字節

要想做好iOS開發,必須要清楚這幾個點!【架構總結出來的經驗

增加 這也 完全 命運 通過 方向 選擇 想要 領導 前言: 每個人的都有獨特的經歷,因此會有特別的事情會讓ta感到快樂,並享受做自己喜歡的事情。寫程序也不例外,我在很年輕的時候就明白這點,它成為我開始創業的無形資產。寫程序的渴望來自我想完整獨立做一件事情的渴望,做移動開發

阿裏資深架構教你如何做到年薪 50 萬的程序員

帶來 邏輯 切入點 遊戲 實現 def 人生 比較 -s 寫在開篇 不管是開發、測試、運維,每個技術人員心裏都有一個成為技術大牛的夢,畢竟“夢想總是要有的,萬一實現了呢”!正是對技術夢的追求,促使我們不斷地努力和提升自己。 然而“夢想是美好的,現實卻是殘酷的”,很多同學在實

10web前端架構總結開發學習路線!附送學習資料!

首先分享一下我的經驗,想做好一件事,必須要花費一些功夫,然後是多學、多思、多練、多交流、多總結,發現自己的問題,然後一定要克服,在狀態不好的情況下,往往要及時調整。新手學習前端的話,一定要想想為什麼要學習它,是出於一種什麼心態,然後定位好自己,多向大牛請教,多教一些沒有自己水平高的人,那樣往往能讓自

15年老架構總結為什麼我們需要Zookeeper?

為什麼需要分散式系統 單機系統已經無法滿足業務需要 高效能硬體價格昂貴 分散式系統帶來哪些問題 叢集中節點資料一致性問題 叢集產生分割槽 負載問題 冪等性問題 可用性問題 Session問題 分散式PAC設計原則 一個經典的分散式系統理論。CAP理論告訴我們:一

生成全域性唯一ID的3個思路,來自一個資深架構總結

標識(ID / Identifier)是無處不在的,生成標識的主體是人,那麼它就是一個命名過程,如果是計算機,那麼它就是一個生成過程。如何保證分散式系統下,並行生成標識的唯一與標識的名稱空間有著密不可分的關係。在世界裡,「潛意識下的名稱空間裡,相對的唯一標識」是

阿裏 P8 資深架構吐血總結的 《Java 核心知識整理&面試.pdf》| 免費分享

park title except 負載 模式 .com 部分 exceptio ase 阿裏 P8 級資深架構師吐血總結的一份 Java 核心知識.pdf, 內容覆蓋很廣,Java 核心基礎、Java 多線程、高並發、Spring、微服務、Netty 與 RPC、Zook

15套java架構、集群、高可用、高可擴展、高性能、高並發、性能優化、Spring boot、Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分布式項目實戰視頻教程

mycat 擴展 並發解決方案 入門到 -1 高端 資料 src nio * { font-family: "Microsoft YaHei" !important } h1 { background-color: #006; color: #FF0 } 15套java

15套java架構、高並發、集群、高可用、高可擴展、高性能、性能優化Redis、ActiveMQ、Mycat、Netty、Jvm

高並發 集群 分布式 多線程 項目實戰 15套Java架構師詳情15套java架構師、集群、高可用、高可擴展、高性能、高並發、性能優化、Spring boot、Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分布式項目實戰視頻教程 視頻課程包含:高級Java架構

15套java架構大型分布式項目實戰視頻教程

騰訊 shiro nts h+ 設計模式 dubbo 相關 數據庫性能優化 ace 15套java架構師、集群、高可用、高可擴 展、高性能、高並發、性能優化、Spring boot、Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分布 式項目實戰

阿裏巴巴十Java架構分享,會了這個知識點的人都去BAT了

工作經驗 java開發框架 人才 一起 跳槽 技術開發 代碼 lis 框架 1.源碼分析專題 詳細介紹源碼中所用到的經典設計思想,看看大牛是如何寫代碼的,提升技術審美、提高核心競爭力。 幫助大家尋找分析源碼的切入點,在思想上來一次巨大的升華。知其然,並知其所以然。把知識變

阿裏資深架構私下峰會:了解這幾點,人人皆是優秀架構

java 源碼分析 分布式 高可用 高並發 前言: 最近有好多人問我說:“George,怎樣才能成為公司裏的前線主力架構師,我現在在公式已經幹了快五年了,現在還是一個默默無聞的程序員,我也通過很多種渠道來突破我現在瓶疾,但就是走不出來,技術也一直沒有突破上去,我真的是沒有辦法了,通過朋友推

7iOS架構-- 告訴你堅持寫博客對我們有什麽好處

復雜 來講 同事 寫作 也快 真的 tps 架構圖 提高自己 一,寫博客的擔心 1.今天來談談,寫博客對我的益處,說起寫博客,其實我寫博客的時間不長,也就10來個月時間; 2.之前工作的時候,看到同事每天晚上寫博客,當時覺得很奇怪,就覺得寫這個東西,非常浪費時間, 3.自己

6iOS架構告訴你程序員到底有沒有前途?【頭條熱門】

所有 成長 更多 通過 什麽 光環 溝通 大學 就是 前言: 1,早上到公司,看昨天晚上QQ群裏的內容,有人在問做iOS程序員怎麽樣。馬上就有人跳出來告訴他程序員又苦、又累,要求又高、賺得也不比人多,而且30歲以後肯定失業那一套。對程序員的前途,自己有自己的想法,但這沒什麽