普通程式設計與專業程式設計之間有很多差別,而最為顯著的就是截止日期。
截止日期 / 最後期限
當你給自己寫程式的時候,只要你願意,就可以用很多(或者很少)的時間來完成,但是當你給別人寫程式的時候,你就只有一點有限的時間和資源來完成任務。而根據我的經驗,一般會導致以下兩種情況之一:
1. 你必須延長時間以妥善完成任務。
2. 你必須寫些不嚴謹的程式碼來應付過關。
如果你做過專業程式設計,你會明白我的意思。只有極少數夠靈活的專案能夠給予足夠的時間和資源來完成任務。這就使得程式設計師必須做出艱難的抉擇。
任何一個有自尊的程式設計師都不願意提交不合格的程式碼;但是當交易中伴隨有超時違約金時,想要始終提交高質量的程式碼是很困難的,尤其是在專業環境下,與那些不需要理解技術違約概念的非技術員交易。
幸好,這裡有幾條準則供你參考,可以在臨近截止日期時,幫你把不嚴謹的程式碼總數最小化。它們不一定能夠快速修復問題,但毫無疑問將有助於那些需要日復一日,始終寫出一流程式碼的人。
準則一:編碼之前設定連續部署
這是我從《The Pragmatic Programmer / 程式設計師修煉之道》一書(絕對是程式設計師的必讀之書)中找出的小竅門。總是,我是說總是,在編碼之前設定你的連續部署系統。
我所說的連續部署是什麼意思?好的,在你開始編寫你的專案之前,你應該有一個能部署你的專案程式碼為產品的系統(最好對於分期和開發環境也是如此)。這樣,當你編碼時,你就會有一個平和的心態,因為你知道你可以隨時部署你的專案。
在很多的程式設計流程中,這一點能節約相當多的開發時間。一些測試環境(或者更糟,直接在伺服器上編碼),你可以直接把程式碼放到你首選的原始碼控制系統中,然後讓你的連續部署系統負責接下來的事情。這也許看起來不想個節約時間的方法,但是如果你考慮一下每天都要把你的程式碼複製過去並手動測試所浪費的時間,你就知道這樣做能快速完成並在每月中節約數小時。
準則二:先寫測試
如果你從沒聽說過測試驅動開發(TDD),請立刻看看維基百科的解釋。如果有人付錢讓你編寫軟體,並且規定了截止日期,你就要隨時練習TDD。
測試驅動開發的基本概念是,在寫專案程式碼之前,你寫一段簡單的程式碼來測試你假設的專案程式碼,以獲得預期的反應。例如:你的專案需要你寫一個函式,把兩個數相加,並返回和。在寫這段程式碼之前,你應該寫一個測試函式,test_add_two_numbers,它呼叫你的add_two_numbers函式來驗證不同的輸入值所返回的結果都是正確的。
這看起來很麻煩,但是它有許多好處:
- 寫測試首先能幫你明確你的應用程式架構。
- 你將有一個平和的心態,因為你知道你的程式碼是可執行的。
- 你能夠輕易的重構專案,而不用擔心破壞程式碼。
- 你可以避免放出低質量的程式碼以免玷汙你的聲譽。
準則三:透明
透明很難實現(取決於你的工作環境),但卻非常有益處。
為了達到透明,你需要確保與接收程式碼的客戶之間保持一條清晰的通訊線路。你需要保持定期更新,這樣才能看出來工作正在進行,並且進展的哪裡。再好一點就是,你能一直部署程式碼到分期系統,從而讓客戶夠看到未完成的專案和它一天天的改變。
如果你能跟你的老闆(們)保持透明化,他們就很有可能瞭解是否需要推遲截止日期。非技術人員通常不懂軟體開發,視它為黑盒技術。通過與客戶保持清晰的通訊和透明化,並讓他們參與到開發程式中,客戶可以更瞭解你的工作,使得對將要開發出來的產品更青睞。
規則四:維持日常計劃表(Todo list)
時間管理問題肯定是超出本文談論的範圍,但是我仍要指出,為確保事情一直向前進展,作為一名程式設計師你所能做的最好的事情之一就是維持一份日常計劃表。另外,一個得力的時間追蹤工具也能幫上大忙。伯樂線上的這篇文章中有老外推薦的10個時間追蹤工具。
軟體開發是極為複雜的事情。成為一名優秀的程式設計師要求有多年的實踐,耐心和鍛鍊,並且學無止境。當需要在截止日期內開發軟體時,往往你正在編寫一個複雜的系統。為保持思路清晰,並且確保發揮你程式設計的最大能力,你應該維持一份由每日需要完成(編碼方向)的單獨的任務組成的日常計劃表。
不要寫過於空泛的計劃表,像“除錯聲音問題”這樣的,而是要真正地想一遍,並且寫出事情的幾個步驟。例如:
- 寫一個音樂檔案載入功能的單元測試,檢查mp3是否能夠播放。
- 寫一個音樂檔案載入功能的單元測試,檢查載入wav檔案時是否崩潰。
- 建立新的特性分支,設計升級,適用於新的網頁設計模板。
- 使用網頁設計新模板升級style.css。
有一個明確的可操作的事件列表可以使你集中力量在一段時間內解決一個單獨的任務。這樣就不用時刻平衡分配和在腦子裡想著接下來的步驟。編寫軟體已經夠複雜的了,不要讓你的生活更困難。
準則五:做應該做的事
毫無疑問,會有令你緊張和不舒服的情況出現。你拖延時間並忽略了新特性的單元測試嗎?當這些情況發生時,不要任意妄為。相反的,做應該做的事。
不管是否需要你回顧還是重新檢視一些舊程式碼,都要多寫一些測試用例,甚至推遲截止日期也要這麼做。作為一位專業的技術人員,持續地開發能夠執行的程式碼是你的工作,即使這意味著你必須做出艱難的抉擇。
結語
對一個軟體開發人員來說沒有輕鬆的任務。我們的世界一直充滿挑戰和困難,只有磨練和時刻準備著才能幫助我們渡過難關,並在好時光裡成功。一直利用我們最精確的判斷,通過運用毫不動搖的工程實踐去打破時間的桎梏並且不向困難低頭。
你能夠做到。