新聞中心
近些年來,越來越多的人開始轉(zhuǎn)向敏捷開發(fā),而且這些敏捷開發(fā)的技術(shù)已不再新鮮,大多都是在80和90年代設(shè)計(jì)形成的。但是,最近幾年,程序員,特別是一些商業(yè)顧問,架構(gòu)師和客戶開始喜歡上了敏捷開發(fā)。

10年積累的做網(wǎng)站、網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有聊城免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
不斷進(jìn)化的需求
現(xiàn)如今,有一個(gè)普遍的認(rèn)識(shí)就是在你開始項(xiàng)目編程之前,你不可能寫下所有的需求,這些需求的確定需要一個(gè)不斷進(jìn)化的過程。在較短的開發(fā)周期中,我們不斷的完善程序,多次迭代從而滿足客戶提出的***需求。這些都是基于進(jìn)化的原則,就像我們的生活,你是一步一步的向前從而做得更好。
不斷進(jìn)化的代碼
這就可以了嗎?現(xiàn)在的大多數(shù)程序員都已經(jīng)認(rèn)識(shí)到了需求是不斷進(jìn)化和完善的。但還不夠,他們依舊認(rèn)為項(xiàng)目使用的框架和架構(gòu)應(yīng)該在項(xiàng)目開始的時(shí)候就確定了,而且代碼一旦完成,就一切都OK了。
錯(cuò)。根據(jù)我的經(jīng)驗(yàn),所有優(yōu)秀的代碼都至少要寫兩遍。***遍寫代碼時(shí),你通常會(huì)很匆忙,不能很好的理解并實(shí)現(xiàn)需求。當(dāng)然,如果你看過一些設(shè)計(jì)模式,知道一些方法,你最終的代碼可能會(huì)寫得不錯(cuò),但它絕不是***秀的。少寫一些無謂的代碼,多一些思考。
在我們現(xiàn)在的項(xiàng)目中,幾乎所有重要的功能都要從零開始寫,并且重復(fù)修改很多次。這雖然很慢,但確定的是寫出的代碼越來越好了。當(dāng)你修改某一部分的代碼已經(jīng)三到四次,或又修補(bǔ)了這里的一個(gè)bug,你就開始有點(diǎn)想躲避這部分代碼,如果不再處理它你就會(huì)很高興。當(dāng)有了這樣的想法后,你肯定會(huì)刪了這些代碼。那就又要一切從頭開始了嗎?
再一次錯(cuò)。確實(shí),IDE里空了,代碼沒了,或許只有一些測(cè)試程序還在。但是,你已經(jīng)對(duì)你寫的這些代碼有了深刻的認(rèn)識(shí),你知道它是什么樣的,你也知道它的問題出在哪。在此基礎(chǔ)上,你現(xiàn)在可以寫出更好,甚至是優(yōu)秀的代碼。當(dāng)然了,我們也可以保留之前的代碼,進(jìn)行一些重構(gòu)等等,但都不如從頭開始,更好的做出它。
這和生活中的道理依然是一樣的,要想把一件事做到極致,就要多次的重復(fù)和進(jìn)化。你的需求是這樣,你的代碼和架構(gòu)也要這樣。
寫兩遍代碼會(huì)花費(fèi)兩倍的時(shí)間?
當(dāng)我告訴人們所有的程序都要至少寫兩遍時(shí),他們擔(dān)心這樣會(huì)使完成整個(gè)項(xiàng)目的時(shí)間加倍。但事實(shí)不是這樣的,我來告訴你原因:
1. 第二次寫代碼,只會(huì)花費(fèi)你***次寫代碼時(shí)的部分時(shí)間;
2. 重寫之后的代碼在質(zhì)量上會(huì)有顯著提高,而且維護(hù)性和可擴(kuò)展性都會(huì)更好,你的編程速度也會(huì)越來越快。
所以,堅(jiān)持重寫你的代碼,不斷優(yōu)化它吧!
原文:http://www.redcode.nl/blog/2011/10/great-code-is-written-twice-or-more/
譯文:http://www.php100.com/html/it/focus/2014/1120/7855.html
(翻譯:PHP100_Zeroing)
網(wǎng)站題目:反復(fù)修改才能創(chuàng)造出優(yōu)秀的代碼
本文URL:http://www.dlmjj.cn/article/coeecep.html


咨詢
建站咨詢
