我的10個(gè)開(kāi)發(fā)原則_第1頁(yè)
我的10個(gè)開(kāi)發(fā)原則_第2頁(yè)
我的10個(gè)開(kāi)發(fā)原則_第3頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、在從事軟件開(kāi)發(fā)若干年之后,我已經(jīng)對(duì)軟件應(yīng)該如何設(shè)計(jì)”有些心得。實(shí)際上,我有了這樣一個(gè)結(jié)論:所有的事 情最后都濃縮成10個(gè)原則,如果我們很好地執(zhí)行這些原則,任何軟件開(kāi)發(fā)都應(yīng)該會(huì)取得成功。0.客戶至上如果我們沒(méi)有關(guān)注客戶.其他人將會(huì)取代我們?!睆目蛻舻慕嵌瘸霭l(fā),客戶首先會(huì)把焦點(diǎn)集中在產(chǎn)品開(kāi)發(fā)的真正價(jià)值,其他方面(例如概念、需求、技術(shù)等等) 在項(xiàng)目中是次要的。不關(guān)注客戶,就是程序員常犯的5個(gè)非技術(shù)性錯(cuò)誤的其中之一。代碼質(zhì)量即使代碼質(zhì)量是一些非常主觀性的東西,(甚至有人說(shuō)所有的代碼都有問(wèn)題),它卻影響著很多重要的方面, 比如:如何去維護(hù)應(yīng)用程序,或者如何去帶一個(gè)新手程序員。在我看來(lái),代碼質(zhì)量的指標(biāo)在于

2、:簡(jiǎn)單性、可讀性、健壯性和可測(cè)試性。其他特性,例如外觀或者可擴(kuò)展性, 如果沒(méi)有要求的話,在你的應(yīng)用程序中可以靈活設(shè)計(jì)。授權(quán)軟件開(kāi)發(fā)過(guò)程中最重要的資源是人力,而非技術(shù)。人力決定產(chǎn)品的好壞,但他們需要得到授權(quán)。授權(quán)是一個(gè)鼓勵(lì)開(kāi)發(fā)者積極做事和制定決策的過(guò)程。一些高效的機(jī)構(gòu)的授權(quán)體現(xiàn)為:指導(dǎo)配合或者委派。不知你是否也有過(guò)和Derek相同的經(jīng)歷,每隔5分鐘就有員工跑過(guò)來(lái)向他請(qǐng)示這個(gè)和那個(gè)問(wèn)題?如果有,可以通過(guò)管理者的困境:放權(quán)或者崩潰這篇文章看看Derek如何解決這個(gè)問(wèn)題的。DelegarionHeres what I need from /ou.This is how you do it.This i

3、s what I want it to look like.This is what you need to do net.Ill give you the last 5%,I own it.Heres where I see this going?ConcreteToe the company line.T asksNo room for other leadersGuided by preference Heres my opinion.EiiipoweniientWhat do you reed from me?This is your role.This is where were g

4、oing.This is how it fits in the big picture.Ill 廚 you contribute the last 5%.You awn it.Where do you see this going?FluidPushback is encouraged.ResultsRoom for other leadersGuided by valuesWhats your opinion?持續(xù)集成從我的經(jīng)驗(yàn)看來(lái),集成是軟件開(kāi)發(fā)的主要問(wèn)題。在項(xiàng)目后期或者大型功能模塊完成后,等著集成是一個(gè)令人 糾結(jié)的過(guò)程。持續(xù)的集成是保證每部分委托的代碼在系統(tǒng)中自動(dòng)集成的過(guò)程。請(qǐng)記住,持續(xù)

5、集成優(yōu)先于持續(xù)編譯。Martin Fowler的這篇文章是網(wǎng)上關(guān)于持續(xù)集成的最優(yōu)秀的參考文獻(xiàn)之一。迭代迭代提供了持續(xù)的反饋信息。持續(xù)反饋很重要,因?yàn)樗档土塑浖_(kāi)發(fā)的不穩(wěn)定性。雖然迭代經(jīng)常與敏捷方法有關(guān)系,不過(guò)有其他方法例如RUP,也使用迭代,他們卻不是敏捷方法家族中的一 員,記住這一點(diǎn)很重要。自動(dòng)化測(cè)試允許重構(gòu)和遞歸,給開(kāi)發(fā)者帶來(lái)自信,如果得到有效貫徹的話,會(huì)提高最終產(chǎn)品的正確性。對(duì)于自動(dòng)化測(cè)試, 你可以考慮與測(cè)試有關(guān)的一些情況和如何編寫一個(gè)良好測(cè)試組件的建議。重構(gòu)不管你如何關(guān)注編碼,在你邁出第一步的時(shí)候,你將會(huì)走錯(cuò)路。重構(gòu)是我們用來(lái)保持代碼修改的做法,以滿 足系統(tǒng)說(shuō)明的必要更迭。非正式架構(gòu)前期的大型設(shè)計(jì),除非你是NASA,能夠把項(xiàng)目50-60%的時(shí)間花在這上面,否則這完全是浪費(fèi),毫無(wú)準(zhǔn) 備去編碼情形也一樣。非正式架構(gòu)是一種折衷解決方案,它在項(xiàng)目發(fā)展的基礎(chǔ)上進(jìn)行討論,并存留于文件,留言 板或者類似的物件之中。溝通軟件開(kāi)發(fā)只與溝通有關(guān)。客戶向軟件開(kāi)發(fā)團(tuán)隊(duì)闡述他想要達(dá)到的目標(biāo),以便于軟件開(kāi)發(fā)團(tuán)隊(duì)能通過(guò)編碼形式 向計(jì)算機(jī)解釋。Wha-t was-What wasThe cutstomer IHdw was theWhat thedgcumenteddeployed|MEd fen.suppo

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論