自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

好代碼不值錢 不是嗎?

開發(fā) 前端
本文是從 Good code is cheap code 這篇文章翻譯而來。當(dāng)我跟做開發(fā)的同事說出這話時(shí),他們的第一反應(yīng)是一種驚愕,然后是將近一個(gè)星期的嘲笑,把它當(dāng)作一個(gè)笑話來講。當(dāng)他們走近看我的表情、知道我是認(rèn)真的時(shí),才收斂一點(diǎn)。

長久以來我一直主張:好代碼是廉價(jià)的代碼。

[[20007]]

當(dāng)我跟做開發(fā)的同事說出這話時(shí),他們的第一反應(yīng)是一種驚愕,然后是將近一個(gè)星期的嘲笑,把它當(dāng)作一個(gè)笑話來講。當(dāng)他們走近看我的表情、知道我是認(rèn)真的時(shí),才收斂一點(diǎn)。

當(dāng)最初的驚愕消退后,他們會(huì)用一些這樣的話來反駁:“好代碼不廉價(jià),好代碼是采用經(jīng)過數(shù)十年計(jì)算機(jī)科學(xué)研究和積累得出的最佳實(shí)踐設(shè)計(jì)模式和方法論建立起來的精心制作的程序代碼。”

我只好繼續(xù)解釋為什么他們給出的好代碼的定義有問題的原因是(這是很多開發(fā)人員都忽視了的一個(gè)原因):知曉各種設(shè)計(jì)模式,框架,技術(shù)技巧只是事情的一方面,而知道何時(shí)該、何時(shí)不該應(yīng)用他們才是更重要的問題。在不知道一種技巧方式如何能對系統(tǒng)的開發(fā)有幫助的情況下,這種模式方法極有可能成為一種開發(fā)的阻礙,而不是一種有益的幫助。

我還要解釋說,我所說的“廉價(jià)的代碼”是指這些代碼只需要很少的人/天數(shù)就能開發(fā)出來,并不是說是由沒有經(jīng)驗(yàn)的開發(fā)人員、在很少的工資報(bào)酬下、用6個(gè)月封閉式、只有烤白薯和豆腐湯可吃的環(huán)境中開發(fā)出來的東西。

但是…設(shè)計(jì)模式畢竟是個(gè)好東西…不是嗎?

當(dāng)然,但它們好在哪里?它們能提供什么好處?

◆容易維護(hù)

◆產(chǎn)品更健壯

◆容易理解

◆易于日后的改進(jìn)提高

◆更好的可跟蹤性

你會(huì)發(fā)現(xiàn)所有的這些最終都落到一點(diǎn)上:從長期的角度看,它們能讓你更快的做事情。這事情有可能是系統(tǒng)遷移,或是增加一個(gè)新功能,不論是什么,通過運(yùn)用這些方法模式,你會(huì)在時(shí)間效率上獲得實(shí)實(shí)在在的好處。

這么說,我們觀點(diǎn)一致嗎?

怎么說呢,讓我給你們說個(gè)例子,我們看看實(shí)現(xiàn)它的幾種方式。

系統(tǒng)

用PHP創(chuàng)建一個(gè)發(fā)郵件的表單,表單里有幾個(gè)表單項(xiàng),用郵件把這些數(shù)據(jù)發(fā)送給某個(gè)人。除此之外,表單里的內(nèi)容還要存入MySQL數(shù)據(jù)庫里。

現(xiàn)在,用什么方式實(shí)現(xiàn)它們最好?按照傳統(tǒng)的說法,采用最好的實(shí)踐設(shè)計(jì)模式,你可能會(huì)想到這些:

◆MVC

◆N-層設(shè)計(jì),包括數(shù)據(jù)庫抽象層

◆對象關(guān)系映射(ORM)

◆可能用到的框架

◆XML配置和相關(guān)模型

◆等等.

我可以說,這簡直是瘋了,客戶的這些需求完全可以用10幾行代碼、一個(gè)小時(shí)里(包括測試時(shí)間)完成,而且所有的那些方法模式所希望達(dá)到的效果(諸如可讀性,可移植性,穩(wěn)定性)都有了。如果使用上面列出的那些,反而真正的會(huì)達(dá)不到這個(gè)目標(biāo),使代碼復(fù)雜化,難于理解和維護(hù)修改。

那現(xiàn)在,假設(shè)客戶又來了,要求做一些改動(dòng),比如要增加一個(gè)管理員的界面。這樣的話,你就勝利了,你已經(jīng)實(shí)現(xiàn)了很多很有用處的東西;然而這是因?yàn)槟阍诘谝淮伍_發(fā)這個(gè)系統(tǒng)時(shí)付出了很大的代價(jià)。我要向你聲明的是,即使我現(xiàn)在把這些簡單的代碼進(jìn)行重構(gòu),增加一些簡單的業(yè)務(wù)層,也仍然比按你要求的那種過度技術(shù)化的初始實(shí)現(xiàn)方案要簡單的多。

再說了,如果客戶要求的只是在表單里增加一個(gè)屬性,那你的N-層設(shè)計(jì)方案會(huì)讓你痛苦不堪,因?yàn)槟阈枰膭?dòng)各個(gè)層,包括那些CRUD代碼。

SCRUM

我發(fā)現(xiàn)Scrum能吸引我的最大一個(gè)原因是它能迫使你敏捷開發(fā);它能迫使你在每個(gè)Sprint結(jié)束的時(shí)候把東西都實(shí)現(xiàn)、發(fā)布。它不會(huì)讓你做出目前用不到的多余的東西;它不會(huì)允許你在實(shí)現(xiàn)東西上有任何所謂“正確方式”的奢侈行為。

相反,在你需要的時(shí)候你才去重構(gòu)。當(dāng)然,這會(huì)有一定的風(fēng)險(xiǎn),因?yàn)樵趯?shí)現(xiàn)某些功能上你會(huì)花去比當(dāng)初已經(jīng)做了一些基礎(chǔ)工作的情況下要更長的時(shí)間。然而,產(chǎn)品開發(fā)就像是一個(gè)沙漠中四處漂移的沙丘,你永遠(yuǎn)不可能準(zhǔn)確的知道一個(gè)產(chǎn)品在將來會(huì)做如何的改動(dòng)。所有的你花在實(shí)現(xiàn)這些很有吸引力的各種模式上的時(shí)間很可能會(huì)成為一種完全的浪費(fèi)。

復(fù)用性

有些人會(huì)指出,我所說的方式產(chǎn)生的代碼不具有太多的復(fù)用性,不能在新開發(fā)的一些其它系統(tǒng)中使用。我對這個(gè)問題的回復(fù)就是,在根本不知道某些東西是否/如何/在哪將會(huì)被復(fù)用的情況下去設(shè)計(jì)一個(gè)可復(fù)用的東西,這就跟去實(shí)現(xiàn)一些你根本用不到的功能或你的應(yīng)用里跟本用不到的功能一樣愚蠢而糟糕。如果你有一個(gè)清楚的遠(yuǎn)見,知道什么地方會(huì)復(fù)用這些東西,這就不同了,因?yàn)槟愦_實(shí)有一個(gè)內(nèi)部的業(yè)務(wù)需求在指導(dǎo)你正確的開發(fā)方向。

我的最后的思考…

◆了解你的設(shè)計(jì)模式,知道它們各自的好處(我一直認(rèn)為,好的程序員和偉大的程序員之間的區(qū)別就在于偉大的程序員理解他們的模式);

◆讓你的代碼廉價(jià):

   ◆當(dāng)模式能夠給你帶來好處,而且為你省時(shí)時(shí)才去使用它們;

   ◆如果不是這樣就不要使用它們(例如:想想你最近的一次為什么要把系統(tǒng)遷移到一個(gè)不同的數(shù)據(jù)庫上?);

   ◆當(dāng)框架能夠幫你提高開發(fā)速度時(shí)才使用它們;

◆在必要的時(shí)候重構(gòu),不要做一些超前性的開發(fā);

我想,如果你能按照這些指導(dǎo)原則做事,你會(huì)發(fā)現(xiàn)開發(fā)周期變短、實(shí)現(xiàn)的代碼更簡潔,易于調(diào)試,易于維護(hù)修改。

原文鏈接:http://www.aqee.net/2011/03/16/good-code-is-cheap-code/

【編輯推薦】

  1. 揭秘:Facebook如何發(fā)布代碼
  2. 25個(gè)不錯(cuò)PHP的游戲編程腳本代碼分享
  3. 程序員應(yīng)該具備的11項(xiàng)基本技能
  4. .NET程序員是否應(yīng)該放棄VB.NET?
  5. 在西方程序員眼里 東方的程序員是什么樣的?
責(zé)任編輯:陳貽新 來源: IT外刊評(píng)論
相關(guān)推薦

2021-09-18 09:52:07

AI 數(shù)據(jù)人工智能

2017-06-14 18:51:29

Web前端工作經(jīng)驗(yàn)

2018-04-04 11:55:29

App隱私移動(dòng)互聯(lián)網(wǎng)

2020-12-04 12:32:34

喬布斯程序員思維

2021-11-26 10:43:35

程序員技能開發(fā)者

2020-10-24 18:30:19

微信支付賬戶移動(dòng)應(yīng)用

2022-12-28 15:35:58

馬斯克推特

2021-11-09 23:08:20

iPhone手機(jī)安卓

2015-09-15 09:08:58

前端程序員高薪

2013-03-26 11:20:05

創(chuàng)業(yè)創(chuàng)業(yè)者創(chuàng)業(yè)失敗

2013-03-12 10:36:51

2022-07-09 20:35:23

數(shù)字化企業(yè)轉(zhuǎn)型

2022-05-07 10:01:20

好代碼壞代碼

2017-03-09 19:16:56

2020-11-20 08:36:59

Jpa數(shù)據(jù)代碼

2015-04-15 15:01:56

代碼好代碼科學(xué)定義

2015-03-25 09:38:09

Android谷歌

2013-03-04 10:08:57

Android路由器路由功能

2016-08-25 17:46:31

代碼組織CRM

2020-12-04 15:07:44

比特幣區(qū)塊鏈技術(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)