【極限編程】簡(jiǎn)介

1. 極限編程簡(jiǎn)介

極限編程(Extreme Programming,XP)是一種敏捷開(kāi)發(fā)方法幕垦,供中小型團(tuán)隊(duì)用于開(kāi)發(fā)需求快速變化的軟件。

美國(guó)軟件工程專(zhuān)家Kent Beck對(duì)極限編程進(jìn)行了解釋?zhuān)?/p>

XP是一種輕質(zhì)量傅联、高效先改、低風(fēng)險(xiǎn)、柔性蒸走、可預(yù)測(cè)仇奶、科學(xué)而充滿樂(lè)趣的軟件開(kāi)發(fā)方法。

極限編程是價(jià)值而非實(shí)踐驅(qū)動(dòng)的高度迭代的開(kāi)發(fā)過(guò)程比驻。其價(jià)值體現(xiàn)在以下幾個(gè)方面:

  1. 簡(jiǎn)單

    在XP中该溯,簡(jiǎn)單被定義為“在管用的前提下,做簡(jiǎn)單的事情”即實(shí)現(xiàn)最簡(jiǎn)單的可行方案别惦。XP認(rèn)為應(yīng)該盡量保持代碼的簡(jiǎn)單狈茉,只要能夠滿足工作需要就行,這樣有利于代碼重構(gòu)和優(yōu)化掸掸。

  2. 交流

    所有的方法都包含在交流過(guò)程中氯庆,而在XP中,這是其核心價(jià)值觀扰付。它側(cè)重于口頭交流堤撵,XP追求有效的交流,而且強(qiáng)調(diào)項(xiàng)目開(kāi)發(fā)人員羽莺、設(shè)計(jì)人員实昨、客戶之間的有效的、及時(shí)的交流盐固,確保各種信息的暢通荒给。

  3. 反饋

    反饋對(duì)于任何項(xiàng)目的成功都是生死攸關(guān)的,在XP中刁卜,有關(guān)軟件狀態(tài)的問(wèn)題是通過(guò)持續(xù)的志电、明確的反饋來(lái)回答的。通過(guò)反饋长酗,達(dá)到迅速交流溪北、編碼、測(cè)試、發(fā)布項(xiàng)目的目的之拨。

  4. 勇氣

    即勇于放棄和重構(gòu)茉继,對(duì)于用戶的反饋,XP程序員要勇于對(duì)自己的代碼進(jìn)行修改蚀乔,即使有些修改可能會(huì)使得原來(lái)已經(jīng)通過(guò)的測(cè)試又出現(xiàn)錯(cuò)誤烁竭,但是經(jīng)過(guò)團(tuán)隊(duì)的共同攻關(guān),最終必然會(huì)取得滿意的效果吉挣。

2. 極限編程的開(kāi)發(fā)過(guò)程及特點(diǎn)

與傳統(tǒng)的開(kāi)發(fā)過(guò)程不同派撕,極限編程的核心活動(dòng)體現(xiàn)在需求——測(cè)試——編碼——設(shè)計(jì)過(guò)程中,因此對(duì)工作環(huán)境睬魂、需求分析终吼、設(shè)計(jì)、編程氯哮、測(cè)試际跪、發(fā)布等提出了新的思路和需求。

  1. 工作環(huán)境

    XP要求每個(gè)參加項(xiàng)目開(kāi)發(fā)的人都擔(dān)任一個(gè)角色喉钢,并履行相應(yīng)的權(quán)利和義務(wù)姆打。所有的人都在一個(gè)開(kāi)放式的開(kāi)發(fā)環(huán)境中工作,最好是在同一個(gè)大房間中工作肠虽,隨時(shí)討論問(wèn)題幔戏,強(qiáng)調(diào)每周40小時(shí)工作制度,不加班税课。

  2. 需求分析

    客戶被納入開(kāi)發(fā)隊(duì)伍闲延。由于客戶不具備計(jì)算機(jī)專(zhuān)業(yè)知識(shí),無(wú)法用專(zhuān)業(yè)術(shù)語(yǔ)明確的描述需求伯复,所以開(kāi)發(fā)人員和客戶在一起慨代,用講故事的方式把需求表達(dá)出來(lái),開(kāi)發(fā)人員根據(jù)經(jīng)驗(yàn)將許多故事組合起來(lái)啸如,或?qū)⑵溥M(jìn)行分解,最終記錄在小卡片上氮惯,這些故事將陸續(xù)被研發(fā)團(tuán)隊(duì)在各個(gè)周期內(nèi)叮雳,按照商業(yè)價(jià)值、開(kāi)發(fā)風(fēng)險(xiǎn)優(yōu)先順序逐個(gè)開(kāi)發(fā)妇汗。

  3. 設(shè)計(jì)

    XP強(qiáng)調(diào)簡(jiǎn)單設(shè)計(jì)帘不,即用最簡(jiǎn)單的辦法實(shí)現(xiàn)每個(gè)小需求。在XP中杨箭,沒(méi)有哪種傳統(tǒng)開(kāi)發(fā)模式中一次性的寞焙、針對(duì)所有需求的總體設(shè)計(jì),這些設(shè)計(jì)只要能夠滿足客戶在當(dāng)前的需求就可以了,不需要考慮將來(lái)可能的變化捣郊,整個(gè)設(shè)計(jì)過(guò)程包括在整個(gè)螺旋式發(fā)展的項(xiàng)目中辽狈。

  4. 測(cè)試

    XP開(kāi)發(fā)人員在編寫(xiě)代碼之前進(jìn)行測(cè)試,而不是在開(kāi)發(fā)完成后再進(jìn)行測(cè)試呛牲。開(kāi)發(fā)人員編寫(xiě)單元測(cè)試刮萌,對(duì)方法以及可能出現(xiàn)問(wèn)題的每個(gè)地方進(jìn)行測(cè)試。編寫(xiě)好對(duì)針對(duì)組件的所有測(cè)試后娘扩,開(kāi)發(fā)人員只編寫(xiě)剛好能夠通過(guò)測(cè)試的代碼着茸。編寫(xiě)這樣的測(cè)試將為系統(tǒng)提供一套完整的測(cè)試,而我們只編寫(xiě)最簡(jiǎn)單的琐旁,能夠管用的代碼涮阔。僅當(dāng)類(lèi)通過(guò)了所有的測(cè)試,編寫(xiě)工作才算完成灰殴。所有這些測(cè)試是極限編程開(kāi)發(fā)過(guò)程中最重要的文檔之一敬特,也是最終交付給用戶的內(nèi)容之一。

  5. 編程

    結(jié)對(duì)編程是極限編程的一大特色验懊,即兩個(gè)人一起使用同一個(gè)屏幕擅羞,同一個(gè)鍵盤(pán),共同完成一段程序的編碼义图。結(jié)對(duì)編程的好處是减俏,可以提高紀(jì)律性,更容易寫(xiě)出優(yōu)質(zhì)代碼碱工,同時(shí)保證編程的流暢進(jìn)行娃承,更重要的是,能夠使得整個(gè)團(tuán)隊(duì)更方便的分享編程經(jīng)驗(yàn)怕篷,有利于新手快速成長(zhǎng)历筝。

  6. 發(fā)布

    XP要求按照開(kāi)發(fā)計(jì)劃,每經(jīng)過(guò)一個(gè)開(kāi)發(fā)周期廊谓,軟件就發(fā)布一次梳猪,而不是像傳統(tǒng)的開(kāi)發(fā)方法那樣,整個(gè)軟件開(kāi)發(fā)完后才發(fā)布蒸痹。在一個(gè)開(kāi)發(fā)周期內(nèi)春弥,開(kāi)發(fā)人員要求客戶選擇最有價(jià)值的user story作為未來(lái)一兩個(gè)星期的開(kāi)發(fā)內(nèi)容,一個(gè)開(kāi)發(fā)周期完成后叠荠,提交給客戶的系統(tǒng)雖然不是最終的產(chǎn)品匿沛,但是已經(jīng)實(shí)現(xiàn)了幾個(gè)客戶認(rèn)為是最重要的story ,因此榛鼎,雖然軟件并不完備但是逃呼,發(fā)布的軟件客戶還是可以真正使用的鳖孤。

3. 極限編程的優(yōu)點(diǎn)

  • 對(duì)公司的開(kāi)發(fā)者而言,XP可以讓開(kāi)發(fā)者專(zhuān)注于編寫(xiě)代碼抡笼,避免了不必要的文案工作及會(huì)議苏揣。它營(yíng)造了更好的工作氛圍,更多學(xué)習(xí)新技術(shù)的機(jī)會(huì)蔫缸,并令你的員工有成就感腿准。
  • 相比于傳統(tǒng)開(kāi)發(fā)方式,通過(guò)XP開(kāi)發(fā)的軟件缺陷更少拾碌。它令公司對(duì)其商業(yè)需求的變化做出更快速的反應(yīng)吐葱,而且價(jià)格低廉,開(kāi)發(fā)者也少有怨言校翔。
  • 從公司管理的角度來(lái)看弟跑,這種方法可以減少你對(duì)牛人的依賴。同時(shí)它也提升了員工滿意度防症。
  • 在XP下孟辑,你無(wú)需設(shè)計(jì)未來(lái)。你設(shè)計(jì)今天蔫敲。整個(gè)理念就是饲嗽,寫(xiě)簡(jiǎn)單代碼,以及在需求改變的時(shí)候相應(yīng)的改變你的設(shè)計(jì)奈嘿。
  • 你的開(kāi)發(fā)人員是兩人結(jié)隊(duì)編程貌虾,從頭到尾都在一起工作。代碼有著統(tǒng)一的規(guī)范性和可讀性裙犹,大家都能夠理解代碼并按照需求改善代碼尽狠。而且,結(jié)隊(duì)編程在一定時(shí)間內(nèi)是最有效率的叶圃。
  • XP項(xiàng)目與傳統(tǒng)軟件開(kāi)發(fā)的最大區(qū)別在于袄膏,XP是以測(cè)試推動(dòng)開(kāi)發(fā)。在XP下可以在編寫(xiě)代碼之前開(kāi)始測(cè)試掺冠。每一個(gè)環(huán)節(jié)的代碼都要100%通過(guò)單元測(cè)試沉馆。沒(méi)有unit-level bug和回歸bug也意味著開(kāi)發(fā)者能夠?qū)W⑺麄冏约旱墓ぷ鳌D愕目蛻舸_立自動(dòng)驗(yàn)收測(cè)試以確認(rèn)該軟件的每一個(gè)功能的運(yùn)行質(zhì)量德崭。
  • 在XP下悍及,每一個(gè)測(cè)試階段之后都可以發(fā)布一個(gè)小體積軟件。最重要的是接癌,每一階段完成時(shí)都有些東西能夠拿給客戶看。
  • 在傳統(tǒng)流水線方式下扣讼,如果項(xiàng)目計(jì)劃變更缺猛,之后要趕上檔期就會(huì)需要很大投入。XP的方法可以令你提前判斷進(jìn)程。
  • 極限編程從最簡(jiǎn)單的解決方案入手荔燎。你可以在之后添加其他功能耻姥。這個(gè)概念的目的在于為今天做計(jì)劃,設(shè)計(jì)及編碼有咨,而不是為了明天琐簇。
  • 來(lái)自系統(tǒng)、客戶和團(tuán)隊(duì)的反饋是極限編程成功的關(guān)鍵座享。在這個(gè)概念的指導(dǎo)下婉商,系統(tǒng)的漏洞在前期就被發(fā)現(xiàn),客戶可以反復(fù)進(jìn)行驗(yàn)收測(cè)試渣叛,從而最大限度的降低你產(chǎn)品中的錯(cuò)誤丈秩。

4.極限編程的缺點(diǎn)

  • 以代碼為中心,忽略了設(shè)計(jì)淳衙;
  • 缺乏設(shè)計(jì)文檔蘑秽,局限于小規(guī)模項(xiàng)目;
  • 對(duì)已完成工作的檢查步驟缺乏清晰的結(jié)構(gòu)箫攀;
  • 質(zhì)量保證依賴于測(cè)試肠牲;
  • 缺乏質(zhì)量規(guī)劃;
  • 沒(méi)有提供數(shù)據(jù)的收集和使用的指導(dǎo)靴跛;
  • 開(kāi)發(fā)過(guò)程不詳細(xì)缀雳;
  • 全新的管理手法帶來(lái)的認(rèn)同度問(wèn)題;
  • 缺乏過(guò)渡時(shí)的必要支持汤求。

5. 極限編程的運(yùn)用

XP適用于規(guī)模小俏险、進(jìn)度緊、需求變化大扬绪、質(zhì)量要求嚴(yán)的項(xiàng)目竖独。它希望以最高的效率和質(zhì)量來(lái)解決用戶目前的問(wèn)題,以最大的靈活性和最小的代價(jià)來(lái)滿足用戶未來(lái)的需求挤牛,XP在平衡短期和長(zhǎng)期之間做了巧妙的安排莹痢。

國(guó)內(nèi)的軟件開(kāi)發(fā)過(guò)程經(jīng)常存在一些問(wèn)題,如:客戶需求變化頻繁墓赴、系統(tǒng)交付時(shí)間一推再推竞膳、交付系統(tǒng)錯(cuò)誤層出不窮、因程序員半途跳槽而導(dǎo)致工作不能順利完成诫硕、需求估計(jì)不足坦辟、因程序員之間交流少而導(dǎo)致代碼重復(fù)開(kāi)發(fā)、文檔不能真實(shí)地反映實(shí)際情況等等章办。為了有效地克服上述問(wèn)題锉走,軟件機(jī)構(gòu)在項(xiàng)目開(kāi)發(fā)時(shí)滨彻,有意識(shí)地采用XP方法,并且取得了一定效果挪蹭。通過(guò)對(duì)這些應(yīng)用的總結(jié)亭饵,可以概括出,XP應(yīng)用確實(shí)具有一定的適用范圍梁厉,而應(yīng)用成功的關(guān)鍵在于辜羊,充分認(rèn)識(shí)XP應(yīng)用過(guò)程中的優(yōu)缺點(diǎn),在保持組織既有的開(kāi)發(fā)過(guò)程和生命周期模型的前提下词顾,結(jié)合應(yīng)用類(lèi)型八秃、項(xiàng)目特點(diǎn)和組織文化,借鑒计技、汲取個(gè)別項(xiàng)目有效的XP方法喜德,在領(lǐng)會(huì)其精神實(shí)質(zhì)的基礎(chǔ)上靈活運(yùn)用,而不是全部照搬硬套垮媒。另外以下幾個(gè)問(wèn)題也是在應(yīng)用中需要注意的:

  • 不同方法的目標(biāo)對(duì)象和適用環(huán)境各不相同舍悯,學(xué)習(xí)和運(yùn)用流行的過(guò)程方法論是實(shí)施過(guò)程改進(jìn)的好辦法,但在具體應(yīng)用過(guò)程中睡雇,應(yīng)整合其最佳元素萌衬,設(shè)計(jì)出適合具體實(shí)際項(xiàng)目的過(guò)程體系。
  • 在軟件工程實(shí)踐中要充分把握好開(kāi)發(fā)技能它抱、軟件過(guò)程和組織管理各個(gè)要素的平衡秕豫,不能偏重某一方面,輕視另一方面观蓄;
  • 在應(yīng)用XP時(shí)混移,應(yīng)該首先從基本實(shí)踐入手,逐漸深入到擴(kuò)展性實(shí)踐侮穿,因?yàn)榛緦?shí)踐彼此獨(dú)立歌径,互不影響,而擴(kuò)展性實(shí)踐則是建立在某些基本實(shí)踐的基礎(chǔ)上的亲茅,而且要采取循序漸進(jìn)回铛、迂回反復(fù)(迭代)的策略,而不是一步到位克锣,這樣容易取得成功茵肃。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市袭祟,隨后出現(xiàn)的幾起案子验残,更是在濱河造成了極大的恐慌,老刑警劉巖巾乳,帶你破解...
    沈念sama閱讀 211,376評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胚膊,死亡現(xiàn)場(chǎng)離奇詭異故俐,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)紊婉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)辑舷,“玉大人喻犁,你說(shuō)我怎么就攤上這事『位海” “怎么了肢础?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,966評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)碌廓。 經(jīng)常有香客問(wèn)我传轰,道長(zhǎng),這世上最難降的妖魔是什么谷婆? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,432評(píng)論 1 283
  • 正文 為了忘掉前任慨蛙,我火速辦了婚禮,結(jié)果婚禮上纪挎,老公的妹妹穿的比我還像新娘期贫。我一直安慰自己,他們只是感情好异袄,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布通砍。 她就那樣靜靜地躺著,像睡著了一般烤蜕。 火紅的嫁衣襯著肌膚如雪封孙。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,792評(píng)論 1 290
  • 那天讽营,我揣著相機(jī)與錄音虎忌,去河邊找鬼。 笑死斑匪,一個(gè)胖子當(dāng)著我的面吹牛呐籽,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蚀瘸,決...
    沈念sama閱讀 38,933評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼狡蝶,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了贮勃?” 一聲冷哼從身側(cè)響起贪惹,我...
    開(kāi)封第一講書(shū)人閱讀 37,701評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎寂嘉,沒(méi)想到半個(gè)月后奏瞬,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體枫绅,經(jīng)...
    沈念sama閱讀 44,143評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評(píng)論 2 327
  • 正文 我和宋清朗相戀三年硼端,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了并淋。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,626評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡珍昨,死狀恐怖县耽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情镣典,我是刑警寧澤兔毙,帶...
    沈念sama閱讀 34,292評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站兄春,受9級(jí)特大地震影響澎剥,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜赶舆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評(píng)論 3 313
  • 文/蒙蒙 一哑姚、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧涌乳,春花似錦蜻懦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至蒸辆,卻和暖如春征炼,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背躬贡。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工谆奥, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人拂玻。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓酸些,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親檐蚜。 傳聞我的和親對(duì)象是個(gè)殘疾皇子魄懂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 2001 年 2 月市栗,在美國(guó)的猶他州,17 位“無(wú)政府主義者”共同發(fā)表了《敏捷軟件開(kāi)發(fā)言》,在宣言中指出: 盡早地...
    ivan_cloud閱讀 1,216評(píng)論 0 0
  • 1填帽、你的測(cè)試職業(yè)發(fā)展是什么蛛淋? 測(cè)試經(jīng)驗(yàn)越多,測(cè)試能力越高篡腌。所以我的職業(yè)發(fā)展是需要時(shí)間積累的褐荷,一步步向著高級(jí)測(cè)試工程...
    歐爾麥特fffff閱讀 4,626評(píng)論 1 41
  • 傳統(tǒng)軟件工程方法的文檔輛過(guò)重??于是出現(xiàn)了 ?? 敏捷開(kāi)發(fā) ?? “輕量級(jí)”方法的軟件開(kāi)發(fā)方法??XP是敏捷開(kāi)發(fā)的...
    Crumvey閱讀 1,331評(píng)論 0 2
  • EOS在主網(wǎng)上線很久前就夸下海口:并發(fā)達(dá)到百萬(wàn)級(jí)哀蘑,延時(shí)達(dá)到毫秒級(jí)诚卸,秒殺以太坊,EOS招招劍指以太坊的軟肋绘迁,BM也和...
    袁曄閱讀 177評(píng)論 0 0
  • 可愛(ài)的小花貓 我家養(yǎng)兩只小貓,一只是白色的卒密,另一只是灰色的缀台。它的耳朵好像兩個(gè)三角形...
    徐媛媛三年級(jí)8班閱讀 84評(píng)論 0 0