天天看點

為什麼軟體工程師應該養成寫作的習慣?

為什麼軟體工程師應該養成寫作的習慣?

在學校裡,有“文科生”和“理科生”的區分,學習内容不同,思維方式也有差異。我是一名理科生,大學裡我的專業是計算機科學,畢業後我的工作是軟體工程師。在這個過程中,我發現文理科之間的鴻溝始終無法彌合。我見到的很多工程師害怕寫文章,而文科生看到代碼就頭疼。

我認為,程式員應該養成寫作的習慣。因為寫文章會鍛煉許多對于程式設計十分有益的技能。

寫文章和寫代碼最核心的共同之處在于它們都需要清晰思考的能力。頂尖的軟體工程師往往也是優秀的寫作者,他們的文章和代碼一樣富有邏輯性,行文流暢、優雅。

文章和代碼有很多相似之處:二者都是從一個空白的頁面開始,把一個想法最終變成完整的産品,推向特定的閱聽人;寫文章和寫代碼都需要你把一系列有邏輯 的語句封裝進一個個子產品中,這些子產品可以是函數也可以是文章的段落;好代碼與好文章一樣都需要言簡意赅,不然就會浪費 cpu 資源或人的精力。

當某個産品快要完工時,軟體工程師會像作品快要發表的作家一樣焦慮不安。和寫文章一樣,軟體永遠不會有徹底完成的時候,工程師需要花更多時間優化代碼、開發新功能或者重做某個部分,因為他們擔心釋出的作品沒有展現出自己最好的一面。

軟體工程師應該寫作因為現在開發協作變得越來越重要。開源項目可以得到來自世界各地人民的參與。開發和營運一個 産品常常需要大量工程師(google maps 有 1100 個全職員工!)。不論是 github 評論、代碼注釋,還是技術文檔都需要清晰準确的文字。良好的寫作能力友善了人們之間的交流,使得項目更好地運作下去。

可能你覺得有些項目不太需要交流協作,但是寫一些關于軟體的内容通常對于學習和更進一步的讨論有着促進作用。現在,我們不再需要通過 rfc 文檔或技術手冊中學習了,因為網上有其他工程師寫的教程。此外,我們還能夠從 hacker news 評論、推特和各種部落格中學到很多内容。

提到部落格,再來說兩句。好的寫作需要時間。我們一開始寫出來的文字可能不怎麼樣,這時就需要再花點時間,多修改幾遍,潤色一下。如果你覺得自己太忙 了沒時間寫部落格,不知道寫什麼或者擔心你的觀點被公開記錄日後留下把柄,你應該花上點時間讀一讀 steve yegge 的《你應該寫部落格》(you should write blogs)這篇文章。即便其中的觀點不能說服你,我相信在閱讀之後你也會有所收獲。

軟體工程師需要寫作,因為他們可能會享受寫作的過程。很多軟體工程師都期待自己開發的軟體能夠“産生影響”,給 人們的生活帶來改變。實際上,通過寫文章,你也能夠對人們“産生影響”,譬如說關于管理的博文可以幫助他人激勵自己的團隊,教授程式設計的内容可能會引起一個 學生學習計算機科學的興趣,關于職業規劃的文章則可以幫助畢業生找到新的職業方向。

即使沒人讀你的文章,寫作的過程也是有益無害。它幫助你理清思路,明确對于某個問題的看法,加強或削弱你的某種觀點。把淩亂的想法彙聚成精簡的文字非常有價值。

總之,寫作有利于提高軟體開發的水準,同時更友善開發過程中的協作,即使對一個理科生來說,也是一件非常值得做的事。

繼續閱讀