又看到一篇關於方法論的文章,觀點還是不錯的。翻譯出來,分享給大家。如果有一項啟發了你,那恭喜你。以下為正文內容: 就像沒有兩片相同的雪花一樣,程式員也各有不同。每一片雪花都是由不同原子以獨特的結構構成。同樣,對於程式員來說無論學習的途徑如何相似,在開發技能和能力上都會有所不同。 即使具有不同天資水平 ...
又看到一篇關於方法論的文章,觀點還是不錯的。翻譯出來,分享給大家。如果有一項啟發了你,那恭喜你。以下為正文內容:
就像沒有兩片相同的雪花一樣,程式員也各有不同。每一片雪花都是由不同原子以獨特的結構構成。同樣,對於程式員來說無論學習的途徑如何相似,在開發技能和能力上都會有所不同。
即使具有不同天資水平,能夠達到行業頂峰或被公認的成功人士通常都是以習慣和技能作為堅實的基礎。這也使他們可以更長久地接近最大效率,併在較長的時間持續獲得更高質量的輸出。
多年參與軟體項目和管理人員的過程中,以下特質在成功人士中脫穎而出。這些技能和習慣不僅可以提高產出的效率和質量,還可以幫助任何人達到更高的水平。
1.尋找有效管理時間的方法
最好的軟體工程師既要編寫代碼,又要作為自己的時間管理者,從而保持較高的效率。
大多數軟體工程師需要獨自完成某些艱巨的開發任務,它們往往需要深入的思考和規劃。這也意味著被干擾和註意力分散的可能性很高。
優秀的工程師瞭解如何避免這些干擾,如何在有效區間中最大化時間,從而產生最大輸出和極限效率。
PS:像“番茄工作法”和“四象限工作法”都是不錯的時間管理法,可根據自己的需要和習慣來運用。
2.遵守編碼標準
你應該始終以一致的風格來編寫代碼。
如果你所在的團隊有一個標準可以遵循,那就太好了。如果沒有,那麼你應該建立自己的標準。遵循標準提供了一套行事準則,隨著時間的流逝會提高輸出的效率和一致性。
個人標準還可以幫助你識別曾經寫的代碼,當需要排查、修改或重構代碼時提供有效的幫助。當你忘記曾經寫的代碼時,統一的編碼風格也可以為你提供熟悉的感覺,從而提升回顧代碼的效率。
PS:規範化是批量化生產的基礎。統一的規範,統一的編碼風格,即使忘記了當初的業務邏輯,也可以快速梳理。
3.儘早且經常與團隊和老闆溝通
世界是互聯的,沒有一個工程師是在真空中工作。
任何正在進行的項目,總會有利益相關者。優秀的軟體工程師會意識到這一點的重要性,並努力確保每個利益相關者(無論相關程度如何)的知情權,並能夠快速瞭解開發的最新狀況。
溝通是優秀團隊合作的基礎,而最好的工程師始終會努力使每個人都持續獲得最新進展。
PS:說溝通是最大的生產力一點不為過,關鍵是還能修正錯誤的認知,產生新的靈感,當然前提是有效溝通。
4.尋找學習的榜樣
總有更多的東西需要學習。
無論多麼擅長某種語言或方法,總會有某些新的事物在某刻出現。作為軟體工程師,成長的最佳方法之一就是跟隨聰明人的腳步,因為他們已經在前面鋪好了路。
這並不需要構建特定的師生關係。團隊中的成員、博客作者、領導以及開源項目都可以為自己的職業生涯提供知識和價值的來源。核心目標就是永不停止地學習。
PS:曾經一直感慨職場中缺少可以學習的榜樣。後來發現,讀書、讀博客、讀源代碼等也是在向榜樣學習。
5.儘早且經常的核查
目前代碼的版本控制已經沒有什麼限制了,易用且只需花很少精力即可完成操作。所以,盡情的使用吧。
因為沒有備份而失去工作,一點都不冤。現有的工具使備份的成本變得微不足道,將其作為工作中優先順序較高的事項來處理吧。
很多軟體都會自動進行備份,出錯的可能性極小,但不是沒有可能。養成經常備份和檢查的習慣是保持持續進步和高效的重要手段。
PS:曾經寫了上百頁的文檔,突然軟體崩潰了,自己也差不多崩潰了,還好最後找回來了大部分的內容。必備技能:Ctrl + S。
6.平衡工作與生活
工作永無止境,企業只會壓榨出你最後的一點價值。
沉浸於一個大項目是很容易發生的事,如果你讓這件事發生,它會耗盡你所有的精力。但大腦需要休息和刺激,而不是通過電腦屏幕、鍵盤和更多的咖啡來保持較高的效率。
周末的存在是有原因的。花一點時間去散步、看一場演出或遛遛狗。當你回來的時,工作就在那裡,你可以通過平衡工作和個人生活來獲得更高的平均產出。
PS:啥都不說了,勞逸結合。如果還在996,就得動點腦筋了,畢竟掙錢是為了更好的生活,更健康的生活。
7.持續進行個人項目
任何人都不可能在各個領域保持處於前沿水平。
即使你正在從事著最前沿的工作,仍然有許多沒有探索或學習的前沿技術。
個人學習和獨立項目是繼續學習新領域的關鍵,而這些領域可能是正常的8-5工作制中所不能涵蓋的。通過個人項目可以使你跟上其他技術領域的發展並與其建立關聯性,創造學習的機會。
PS:以項目實戰引領學習節奏。
8.學會準確預估
工作是按日期和時間表進行的。
無論你的開發方法有多敏捷,總會在某刻出現一個問題:“什麼時候能準備好?”
通過瞭解自己的工作習慣以及單位時間的產出,可以更輕鬆地得到一個準確的答案。訣竅是要在正式加入團隊之前就瞭解到這一點。瞭解自己的能力和局限性可以讓你更自信更準確地回答這個問題。
9.註解代碼
隨著時間的推移,你會逐漸遺忘為什麼用這種方式來實現這個函數。
未來的某一天,回顧舊代碼時,需要花費同樣的精力來理解代碼是你還是其他人寫的。註解代碼提供了一種方式,使任何人(包括你自己)都可以快速瞭解上下文內容,從而可以排查、維護或修改軟體。
當使用註解成為一種習慣,不僅可以跨越時間的保留當初設計的初衷,而且還可以獲得比閱讀代碼更好、更快的理解和處理複雜業務邏輯的優勢。
PS:永遠不要相信你的記憶力。多篇文章中都提到文檔和註解的作用。一個月後看自己的代碼與看別人的代碼基本上沒啥區別。
10.學習如何對自己的工作進行質量檢查
沒有人比編寫軟體的人更瞭解軟體的優勢和局限性。
在將新特性和功能交付他人review之前,執行自己的質量檢查(QA)是編寫穩定、完整軟體的寶貴工具。
學習和實踐測試驅動開發(TDD)等技能,並瞭解如何有效地對自己的代碼進行360度審查,尋找邊界情況,將使你在輸出質量方面遠遠超過其他人。不管這個過程看起來多麼無聊或耗時,學習如何有效地進行質量檢查將使你成為一個更好的軟體工程師。
PS:只能說自測是一種美德。
作為軟體工程師,越早養成成功的習慣和技能,你的職業將會越成功。記住要繼續閱讀和學習,永不放棄!