近些年來,越來越多的人開始轉向靈活開發,而且這些靈活開發的技術已不再新鮮,大多都是在80和90年代設計形成的。但是,最近幾年,程式員,特别是一些商業顧問,架構師和客戶開始喜歡上了靈活開發。
不斷進化的需求
現如今,有一個普遍的認識就是在你開始項目程式設計之前,你不可能寫下所有的需求,這些需求的确定需要一個不斷進化的過程。在較短的開發周期中,我們不斷的完
善程式,多次疊代進而滿足客戶提出的最新需求。這些都是基于進化的原則,就像我們的生活,你是一步一步的向前進而做得更好。
不斷進化的代碼
這就可以了嗎?現在的大多數程式員都已經認識到了需求是不斷進化和完善的。但還不夠,他們依舊認為項目使用的架構和架構應該在項目開始的時候就确定了,而且代碼一旦完成,就一切都ok了。
在我們現在的項目中,幾乎所有重要的功能都要從零開始寫,并且重複修改很多次。這雖然很慢,但确定的是寫出的代碼越來越好了。當你修改某一部分的代碼已經
三到四次,或又修補了這裡的一個bug,你就開始有點想躲避這部分代碼,如果不再處理它你就會很高興。當有了這樣的想法後,你肯定會删了這些代碼。那就又
要一切從頭開始了嗎?
再一次錯。确實,ide裡空了,代碼沒了,或許隻有一些測試程式還在。但是,你已經對你寫的這些代碼有了深刻的認識,你知道它是什麼樣的,你也知道它的問
題出在哪。在此基礎上,你現在可以寫出更好,甚至是優秀的代碼。當然了,我們也可以保留之前的代碼,進行一些重構等等,但都不如從頭開始,更好的做出它。
這和生活中的道理依然是一樣的,要想把一件事做到極緻,就要多次的重複和進化。你的需求是這樣,你的代碼和架構也要這樣。
寫兩遍代碼會花費兩倍的時間?
當我告訴人們所有的程式都要至少寫兩遍時,他們擔心這樣會使完成整個項目的時間加倍。但事實不是這樣的,我來告訴你原因:
1.第二次寫代碼,隻會花費你第一次寫代碼時的部分時間;
2.重寫之後的代碼在品質上會有顯著提高,而且維護性和可擴充性都會更好,你的程式設計速度也會越來越快。 是以,堅持重寫你的代碼,不斷優化它吧!
來源:51cto