1. 熱愛編程
2. 完成事情
3. 持續(xù)重構(gòu)代碼
4. 使用設(shè)計模式
5. 編寫測試
6. 善用現(xiàn)有代碼
7. 專注可用性
8. 編寫可維護的代碼
9. 能用任何語言編程
10. 知曉基本的計算機科學(xué)
1. 熱愛編程
編程是一種為了滿足興趣而心甘情愿去做的勞動(Programming is a labor of love)。和其他任何職業(yè)一樣,唯有真正的熱情,才能完成真正的偉大事情。這里有個誤解,認(rèn)為編寫代碼是機械化并純科學(xué)性的。事實上,最優(yōu)秀的軟件工程 師是工匠,他們能把能量、獨創(chuàng)性和創(chuàng)造力融入到每一行代碼中。偉大的工程師知道何時該把代碼雕琢至完美,知道何時把大型系統(tǒng)像拼圖一樣組裝到一塊。熱愛編 程的工程師從構(gòu)建軟件中獲得滿足,就好比一位作曲家在完成一部交響樂后而欣喜若狂。正是興奮感和成就感,才造就了喜愛編程的明星工程師。
2. 完成事情
有很多技術(shù)人員只談?wù)撥浖痪帉懘a(只說不做型)。而偉大軟件工程師會真正去編碼,這也是他們最為重要的品質(zhì)之一。他們是實際做事的人。聰明人都 知道,解決問題的最佳途徑是直面問題,而不是花上數(shù)周來設(shè)計復(fù)雜又不必要的架構(gòu)和函數(shù)庫。優(yōu)秀工程師應(yīng)當(dāng)會問:解決手頭問題的最簡單方法是什么?最近的軟 件開發(fā)方法——敏捷實踐,正是專注那個。它的思想是,把復(fù)雜的項目拆分為短小的迭代,每個迭代只關(guān)注一小部分的增量功能。因為每個迭代對應(yīng)的編碼只需要數(shù) 周,所以功能易于管理并簡單。
3. 持續(xù)重構(gòu)代碼
編碼很像雕刻。要像藝術(shù)家一樣不斷完善自己的作品,軟件工程師也要通過可能的最佳方式來持續(xù)完善自己的代碼,以達到目標(biāo)。重新塑造代碼的原則稱為“重 構(gòu)”,Martin Fowler在他的創(chuàng)意書中有相應(yīng)描述。重構(gòu)背后的原始思想是:改善代碼而不改變其功能,移動調(diào)整部分代碼以確保系統(tǒng)不腐,還有確保系統(tǒng)完成基于當(dāng)前需求 該完成的事。持續(xù)重構(gòu)可以讓開發(fā)人員解決另一個著名的問題——“黑盒遺留代碼”(這個問題基本無人想觸及)。
幾十年的軟件開發(fā)文化要求我們,不應(yīng)該去改變正常工作的東西。然而,隨著時間推移,問題是我們成為了老舊代碼的奴隸,老舊代碼變得不穩(wěn)定和不兼容。而 重構(gòu)正好可以改變這一狀況,因為我們是代碼的主人,不是它的奴隸。重構(gòu)在工程師和代碼之間建立起持續(xù)的“對話”,并帶來所有權(quán)、確定性、自信心和系統(tǒng)的穩(wěn) 定性。
千萬不要成為老舊代碼的奴隸。如果代碼是他人所寫,或許你可以輕易推脫責(zé)任。但大多數(shù)時候,那些代碼是自己所寫,要拿得起放得下,舊代碼該埋時,就把它埋了!
4. 使用設(shè)計模式
自從所謂的“四人幫”(Erich Gamma、Richard Helm、Ralph Johnson和John Vlissides)發(fā)表他們的著作——《設(shè)計模式》后,全世界的軟件工程師一直都在討論模式。在我們所處世界,不管是自然界還是人類行為,模式無處不 在。軟件工程自然也不例外。模式就是不斷重現(xiàn)的跨語言跨系統(tǒng)的場景和機制。一位優(yōu)秀的工程師通常能識別并利用模式,而不是受制于模式。工程師不應(yīng)(強制) 讓系統(tǒng)去適應(yīng)某種模式,而需發(fā)現(xiàn)在系統(tǒng)中使用模式的時機(恰當(dāng)使用模式)。在使用模式來確保正確性時,應(yīng)借鑒利用前人的智慧結(jié)晶,使用以前能正當(dāng)解決特定 工程問題的方法。但請切記:模式不是萬靈藥;不要為了使用設(shè)計模式而使用設(shè)計模式。
5. 編寫測試
曾有段時間,軟件工程師們認(rèn)為測試不值得他們?nèi)プ。然而,如果你不做測試,你怎么能確保代碼就能正常工作呢?敏捷實踐中的“單元測試”已獲得普遍認(rèn) 可,因為它注重編寫測試來反映代碼是否有效。隨著系統(tǒng)增大,測試也隨之增大。有經(jīng)驗的工程師知道并了解測試的價值所在,因為測試的目的就是創(chuàng)建一個能正常 運作的系統(tǒng)。優(yōu)秀的工程師通常會確保出現(xiàn)過一次的Bug不會再出現(xiàn)第二次。但優(yōu)秀的工程師也知道,不應(yīng)該浪費時間寫那些瑣碎或多余的測試,而需要專注測試 各個組件中的核心部分。
6. 善用現(xiàn)有代碼
“重新發(fā)明輪子”一直是軟件行業(yè)中的巨大問題之一。從發(fā)明新語言到從寫函數(shù)庫,忽視并重寫那些已經(jīng)存在并已能工作的奇怪驅(qū)動力,已經(jīng)造成大量軟件開發(fā) 的失敗案例。一位明星工程師會專注三種基本類型的重用:第一,內(nèi)部基礎(chǔ)架構(gòu)的重用,相應(yīng)代碼是他自己或同事編寫的;第二,使用第三方的函數(shù)庫,比如 JDK。最后,研究使用某些大型網(wǎng)絡(luò)服務(wù)商提供的相應(yīng)服務(wù),比如Amazon?傊,正確善用現(xiàn)有的代碼,使得軟件工程師能真正專注于最為重要的事情上 ——應(yīng)用程序本身。
7. 專注可用性
優(yōu)秀的工程師通常都專注于用戶。無論用戶是企業(yè)還是個人,無論是為消費型的軟件公司還是投資銀行,需要關(guān)注的都是可用性。用戶如何和系統(tǒng)交互?系統(tǒng)是 否提供一種簡單、直接和平穩(wěn)的操作體驗?有種說法,因為軟件工程師是技術(shù)人員,他/她和“用戶如何與系統(tǒng)交互”沒有關(guān)聯(lián),這種說法嚴(yán)重錯誤。優(yōu)秀工程師努 力工作是為了什么?不正是讓系統(tǒng)簡單并易于使用。他們無時無刻都會想到用戶,不會嘗試去發(fā)明那些令人費解,只有極客才能理解并欣賞的東西。
有些時候,一些軟件工程師過于投入,反而忘記所編寫的程序/軟件,是供他人使用,不是做給自己看的“藝術(shù)品”。所以,在軟件開發(fā)過程中,一直要把“用戶”放在心中。
8. 編寫可維護的代碼
軟件開發(fā)界的另外一個小秘密是:編寫優(yōu)秀代碼和糟糕代碼所花費的時間是一樣多。一位訓(xùn)練有素的工程師,他/她會從第一行代碼開始就考慮可維護性和代碼 的演化。沒有任何理由編寫“丑陋”的代碼、長達數(shù)頁的函數(shù),或是稀奇古怪的變量名。優(yōu)秀的工程師編寫代碼會遵循命名慣例,代碼編寫緊湊、簡單和不過度炫耀 聰明。代碼的每一行,都應(yīng)恰如其分地展現(xiàn)出其原有目的。在給不便理解的代碼(塊)合理注釋時,別忘了命名規(guī)則。清晰明了的函數(shù)名和變量名可以讓代碼不言而 明。
在編碼時,有些程序員會有這種心態(tài):過一會兒再來修改或完善某部分代碼或某條語句。但誰知這一“過一會”竟然是“一天”、“一周”、“一個月”或“一 年”,甚至以后根本就沒機會再回頭修改。所以,盡量別妥協(xié)寫出暫時堪用的代碼。否則,不僅不會節(jié)省開發(fā)時間,也可以阻礙整個進程。當(dāng)然也不利于后續(xù)維護人 員的工作。
9. 能用任何語言編程
優(yōu)秀的軟件工程師活血有自己一門特別鐘愛的編程語言,但從不會執(zhí)迷于當(dāng)中。如今已有很多優(yōu)秀的編程語言,也就是說,如果你只會使用其中一門語言,說明 你缺乏多樣性。你可以用Java、C#或C++編寫任何現(xiàn)代軟件,可以用PHP、Perl或Ruby編寫任何網(wǎng)站的后臺。簡而言之,編程所用語言,遠遠沒 有語言相應(yīng)的函數(shù)庫重要。優(yōu)秀的工程師能夠認(rèn)知到這一點,并愿意去學(xué)習(xí)新語言、新函數(shù)庫和構(gòu)建系統(tǒng)的新方法。
10. 知曉基本的計算機科學(xué)知識
最后,但肯定不是優(yōu)秀工程師最不重要的特質(zhì)就是:扎實的基礎(chǔ)。優(yōu)秀的工程師或許并沒有計算機科學(xué)的學(xué)位,但他/她必須知道基礎(chǔ)——數(shù)據(jù)結(jié)構(gòu)和算法。如 果不知道哈希表,或者不知道鏈表和數(shù)組之間的差別,你如何構(gòu)建一款大型的軟件?。這些都是每位從事軟件開發(fā)的開發(fā)人員應(yīng)當(dāng)知道的。算法也同樣重要,從二分 查找到各種排序,到圖形遍歷,一位明星工程師必須知道并內(nèi)在消化這些基礎(chǔ)東西。因為這些基礎(chǔ)就是你在構(gòu)建任何現(xiàn)代軟件中做抉擇時的必備品。
結(jié)束語
以上就是區(qū)分偉大軟件工程師的諸多特質(zhì)。其中討論的“熱情”,是非常重要的。代碼重用、設(shè)計模式、基礎(chǔ)數(shù)據(jù)結(jié)構(gòu)和算法都是必須知道的,而敏捷實踐中的重構(gòu)和單元測試則有助于工程師應(yīng)對復(fù)雜的軟件。尤為重要的是,明星工程師相信簡潔和常識。也正是這些信念,幫助他們成功構(gòu)建當(dāng)今世界所需的看似不可能又錯綜復(fù)雜的系統(tǒng)。
引用網(wǎng)上看到的一段話:對于知識,要求知若渴;對于自己,要虛懷若谷。保持開放的心態(tài),保持孩童般的好奇心看待新鮮事物。