敏捷軟件開發

群迭代和增量开发方法

敏捷軟件開發(英語:Agile software development),又稱敏捷開發,是一種應對快速變化需求的軟件開發模式,描述了一套軟件開發的價值和原則。此模式中,自組織的跨功能團隊在緊密的協作中發掘用戶顧客的需求以及改良解決方案,[1]此模式也強調適度的計劃、進化開發、提前交付與持續改進,並且鼓勵快速與靈活的面對開發與變更。[2][3]這些原則支援許多軟件開發方法的定義和持續進化。

「敏捷」(Agile 或 agile[4])一詞由「敏捷軟件開發宣言」(Manifesto for agile software development)[5]中開始普及,「敏捷軟件開發宣言」定義了相關的價值和原則。敏捷軟件開發的框架不斷的發展,兩個最廣泛被使用的是 ScrumKanban[6]

詞源

編輯

敏捷一詞來源於2001年初美國猶他州雪鳥滑雪聖地的一次敏捷方法發起者和實踐者(他們發起組成了敏捷聯盟)的聚會。

迭代和增量式軟件開發方法可以追溯到1957年。進化式專案管理和適應性軟件開發出現在1970年代初期。在1990年代,因針對重量級的軟件開發方法的批評,而發展了許多輕量化的軟件開發方法、計劃與細微化開發管理。包含了,從1991年開始的迅速應用程式開發、從1994年開始的統一處理程式與動態系統開發法(DSDM)、從1995年的Scrum、從1996年的水晶清透法與極限編程法、1997年的功能驅動開發。雖然那些開發法都起源於敏捷開發宣言之前,但都統稱為敏捷軟件開發法。在此同時,製造業航空業也遭遇相同變化。

在2001年,十七名軟件開發人員在猶他州的雪鳥度假村會面,討論這些輕量級的開發方法,並由Jeff Sutherland,Ken Schwaber和Alistair Cockburn發起,一同發佈了「敏捷軟件開發宣言」。

在2005年,由Alistair Cockburn和Jim Highsmith領導的小組編寫了一份項目管理原則的附錄,即「相互依存聲明」,以便根據敏捷軟件開發方法來指導軟件專案管理。

在2009年,羅伯特·C·馬丁英語Robert C. Martin(Robert C Martin)編寫了軟件開發原則的擴展,即軟件工藝宣言(Software Craftsmanship Manifesto),根據職業行為和掌握程度來指導敏捷軟件開發。

在2011年,敏捷聯盟創建了敏捷實踐指南(2016年更名為「敏捷詞彙」)、敏捷實踐、術語和元素工作定義的演化開放式彙編,以及來自敏捷從業者社群的經驗指南。

價值觀

編輯

雪鳥會議共同起草了敏捷軟件開發宣言。其中最重要的部分就是對一些與會者一致同意的軟件開發價值觀的表述。[7][8]其中包括了以下方針:

  • 個人與互動:重於流程與工具
  • 可用的軟體:重於詳盡的文件
  • 與客戶合作:重於合約協商
  • 回應變化:重於遵循計劃

雖然他們也很重視右邊的內容,但是更重視左邊的內容。相關術語的意思是:

  • 個人和互動:自我組織和動機是重要的,像共同定位和雙人程式開發,這樣作業模式中的溝通是重要的。建立一個良好的溝通和協作的開發團隊,優於一個孤立運行的專家團隊。溝通是一個基本的概念。
  • 工作軟件:工作軟件比在會議中向客戶呈現檔案更有用並更受歡迎。最好的做法是和程式碼一起評論,保持外部檔案的輕量化,而不是沉重的檔案,後者需要花費很大的精力,且很快就會過時。
  • 客戶協作:在軟件開發週期的初始階段,需求無法完全收集,所以最好直接涉及到付費客戶、最終用戶或者代理,以便在反饋的基礎上逐步闡述和調整詳細的需求。
  • 回應變化:敏捷軟件開發方法的重點是快速響應變化和持續發展。

一些軟件開發者組織了敏捷聯盟,為非營利組織,根據宣言的價值觀和原則促進軟件開發。吉姆·海史密斯英語Jim Highsmith(Jim Highsmith)代表敏捷聯盟(Agile Alliance)介紹宣言:

總覽

編輯

迭代、漸進和進化

編輯

大多數敏捷開發方法將產品開發工作細分微小化,因此大大的減少了前期規劃和設計的數量。迭代或衝刺都是短時間的框架(時間),通常持續一到四周。每個迭代都具有跨功能、職能的團隊,包含了規劃、分析、設計、程式編碼、單元測試和驗收測試。在迭代結束時,將工作產品向利益相關者展示。透過上述方式讓整體風險降至最低,並使產品能夠快速適應變化。迭代的方式,可能不會一次增加足夠的功能來保證可立即發佈使用,但是目標是在每次迭代結束時,有一個可用的發行版(最小化程式缺點)。因此完整產品的發佈或新功能可能需要多次迭代。

工作軟件是進化的主要手段

編輯

高效率的面對面溝通

編輯

無論採用哪種開發方式,每個團隊都應該包含一個客戶代表(Scrum中的產品負責人)。這個人是由利益相關者同意代表他們行事,並作出個人承諾,回應開發人員在開發迭代過程中的問題。在每次迭代結束時,利益相關方和客戶代表將審查進度並重新評估優先級,以優化投資回報(ROI)並確保與客戶需求和公司目標保持一致。在敏捷軟件開發中,會在開發團隊附近設置一個訊息發佈器(通常很大)實體顯示器,甚至路人也可以看到它。它提供了最新的產品開發狀態摘要。並透過建置狀態指示燈以通知團隊他們的產品開發的當前狀態。

非常短的反饋迴路和適應週期

編輯

敏捷軟件開發中的一個共同特點就是每日站會(也在scrum中被稱為日常scrum)。 在一個簡短的會議中,團隊成員相互報告他們前一天對於團隊的迭代目標、今天打算做的目標以及他們可以看到的任何障礙或阻礙。

質素焦點

編輯

經常使用諸如持續整合、自動化單元測試、配對程式開發、測試驅動開發設計模式、領域驅動設計,程式碼重構和其他技術的特定工具和技術來提高質素和提高產品開發敏捷性

哲學

編輯

與傳統軟件工程相比,敏捷軟件開發主要針對具有動態、非確定性和非線性特徵的複雜系統和產品進行開發。準確的估計、穩定的計劃和預測往往很難在早期達到,因此對它們的信心可能很低,在獲得價值的證據之前,敏捷開發從業人員需要相當的的信心。 需求和設計被認為是緊急情況下,過大的前期規格可能會造成很多浪費,在經濟上也不划算。 由行業從多年經驗的成功和失敗中學到的這些基本論點。

適應性與預測性

編輯

從適應到預測的軟件開發法存在於連續體中,敏捷軟件開發法倚靠連續體的適應性面。適應性開發法的一個關鍵是透過「滾動波」法進行計劃。其中確定了里程碑,但留下了靈活性,以達到他們的路徑,也允許里程碑本身的改變。

適應性方法的重點是快速適應不斷變化的現實。當專案需求發生變化時,適應性團隊也會發生變化。 自適應團隊很難描述未來會發生什麼。 離專案目標日期越遠,適應性方法越是模糊,越無法確知那天會發生什麼變化。一個自適應的團隊無法準確地報告他們下週將要完成的任務,而只是他們下個月計劃的功能。當被問及六個月後的發佈時,一個自適應團隊可能只能報告發佈的使命聲明,或預期價值與成本的聲明。

相較之下,預測法着重於詳細分析和規劃未來,並迎合已知的風險。在極端情況下,預測團隊可以準確報告在整個開發過程中計劃的功能和任務。預測法依靠有效的早期階段分析,如果這樣做很不妥,專案可能難以改變方向。預測團隊通常設立一個變更控制委員會,以確保他們只考慮最有價值的變化。

風險分析可以於自適應(敏捷或價值驅動)和預測(計劃驅動)法之間進行選擇。巴里·伯姆英語Barry Boehm(Barry Boehm)和理查德·特納(Richard Turner)認為,連續統一體的每一面都有自己的主場,如下表所示:

價值驅動法 計劃驅動法 正式法
低臨界 高關鍵性 極端的危險
資深開發人員 初級開發者 資深開發人員
需求經常變化 需求不經常改變 有限的需求
少量的開發人員 大量的開發人員 可以建模的需求
響應變化的文化 要求秩序的文化 極致的質素

疊代法與瀑布法

編輯

敏捷軟件開發法和瀑布法之間的區別,其中之一就是質素和測試方法。在瀑布模型中,構建階段之後總是有單獨的測試階段; 但是,在敏捷軟件開發測試中,與編程相同的疊代完成。

由於測試是在每一次疊代中完成的-開發一小部分軟件,用戶可以經常使用這些新的軟件並驗證其價值。用戶知道更新後的軟件的真實價值後,可以對軟件的未來作出更好的決策。在每次疊代中進行一次價值回顧和軟件重新計劃會話 - Scrum通常只有兩個星期的疊代循環 - 幫助團隊不斷調整自己的計劃,以最大限度地提高其價值。 遵循與PDCA循環類似的模式,因為工作已經計劃、完成、檢查(在審查和回顧中),並且任何商定的變更都會被執行。

這種疊方法支援產品更甚於專案思維。這在整個開發過程中提供更大的靈活性; 而在專案中,需求是從一開始就定義和鎖定的,以後很難改變它們。疊代開發允許軟件產品根據業務環境或市場需求的變化而發展。由於敏捷軟件開發的疊代方式較短,因此與精益創業概念有着密切的聯繫。

程式碼與文件

編輯

在給IEEE計算機的一封信中,Steven Rakitin表達了對敏捷軟件開發的憤世嫉俗,稱敏捷開發為 "一個破壞軟件工程規範的嘗試" ,並將 "將軟件工作在綜合性文件之上" 翻譯為 "我們要花時間編碼。請記住,真正的程式設計師不寫文件 。"

敏捷軟件開發的支持者認為,開發人員應該編寫文件,如果這是實現相關目標的最佳途徑,但是與編寫靜態文件相比,往往有更好的方法來實現這些目標。斯科特·安布勒(Scott Ambler)指出,文件應該做到「夠好」即可,過多或全面的文件通常會造成浪費,開發人員很少相信詳細的文件,因為它通常與程式碼不同步,而文件太少 也可能導致維護、溝通、學習和知識共用的問題。Alistair Cockburn寫了透明清晰法:

原則

編輯

宣言中還包括以下原則:[9] [10]

  • 我們最優先的任務,是透過及早並持續地交付有價值的軟體來滿足客戶需求。
  • 竭誠歡迎改變需求,甚至已處開發後期亦然。敏捷流程掌控變更,以維護客戶的競爭優勢。
  • 經常交付可用的軟體,頻率可以從數週到數個月,以較短時間間隔為佳。
  • 業務人員與開發者必須在專案全程中天天一起工作。
  • 以積極的個人來建構專案,給予他們所需的環境與支援,並信任他們可以完成工作。
  • 面對面的溝通是傳遞資訊給開發團隊及團隊成員之間效率最高且效果最佳的方法。
  • 可用的軟體是最主要的進度量測方法。
  • 敏捷程序提倡可持續的開發。贊助者、開發者及使用者應當能不斷地維持穩定的步調。
  • 持續追求優越的技術與優良的設計,以強化敏捷性。
  • 精簡──或最大化未完成工作量之技藝──是不可或缺的。
  • 最佳的架構、需求與設計皆來自於能自我組織的團隊。
  • 團隊定期自省如何更有效率,並據之適當地調整與修正自己的行為。

敏捷軟件開發方法

編輯

敏捷軟件開發法支援廣泛的軟件開發生命週期。有的專注於實踐(例如,極限編程、務實編程,敏捷建模),而有的專注於管理工作流程(例如Scrum,看板)。有的支援需求規範和開發(例如FDD)的活動,而另一些則試圖涵蓋整個開發生命週期(例如DSDM,RUP)。

流行的敏捷軟件開發框架包括(以下列舉常見的方法):

敏捷軟件開發實踐

編輯

敏捷軟件開發得到了許多具體實踐的支援,涵蓋了需求、設計、建模、編碼、測試、計劃、風險管理、流程、質素等方面。一些值得注意的敏捷軟件開發實踐包括:

敏捷聯盟提供了一個全面的線上指南來應用敏捷與相關做法。

剪裁法

編輯

在文獻中,有不同的術語指適應法的概念,包括「剪裁法」、「片段適應法」和「情景方法工程」。 方法剪裁被定義為:一個程式或能力,在這個程式或能力中,人類代理程式通過在情境、意圖和方法片段之間的響應變化和動態的相互作用來確定特定項目情境的系統開發方法。

幾乎所有的敏捷方法都適用於剪裁法。即使是DSDM方法也被用於此目的,並且已經成功地在CMM環境中進行了客製化。敏捷法和傳統的軟件開發法之間的情境適應性,可以被認為是一個明顯的特徵,後者因規範而相對更加僵化。敏捷法實際的含義是可以使產品開發團隊根據個別產品的需求來調整工作實踐。實踐是作為方法框架一部分的具體活動和產品。在更為極端的層面上,可以調整由多種原則組成的方法背後的哲學(Aydin,2004)。

某些方法,如Scrum和極限編程,使得方法適應的需求是明確的。有了這些不太規範的框架,原則之一就是沒有一個程式適合每一個產品的開發,而是應該根據產品的需求量身定做。 Mehdi Mirakhorli提出了一個剪裁實踐,為適應所有實踐提供了足夠的路線圖和指導方針。RDP 的實踐是為極限編程而設計的。這種做法首先作為ICSE 2008會議APSO研討會上的一篇長篇研究論文提出,是目前唯一提出並且適用於客製化極限編程的方法。雖然它是專門針對極限編程的解決方案,但是這種做法有擴展到其他方法的能力。乍看之下,這種做法似乎屬於靜態方法適應的範疇,但RDP實踐的經驗表明,它可以像動態方法適應一樣對待。靜態方法適應和動態方法適應之間的區別是微妙的。

Scrum不是為剪裁法而設計的。 Schwaber指出:「Scrum不是一種需要加強的方法,這是我們首先遇到的麻煩,認為問題沒有一個完美的方法,努力集中在企業所需的變化上。 Bas Vodde強調了這一說法,表明Scrum不像傳統的大型方法論,需要你「挑選」元素。 這是基礎知識的基礎上,您添加額外的元素來本地化和使用情況。

大規模,離岸和分佈式

編輯

敏捷軟件開發被廣泛認為非常適合於某些類型的環境,包括從事綠地項目的小型專家團隊,在擁有傳統基礎架構的大型組織中採用敏捷軟件開發方法所遇到的挑戰和局限性, 記錄和理解。

作為回應,一系列的策略和模式已經發展成為克服大規模開發工作(> 20個開發人員)或分佈式(非集中式)開發團隊等挑戰; 現在有幾個公認的框架,試圖減輕或避免這些挑戰。

  • 規模敏捷框架(SAFe),Dean Leffingwell等等
  • 紀律敏捷交付(DAD),Scott Ambler等等
  • 大規模Scrum(LeSS),Craig Larman和Bas Vodde
  • Nexus(縮放專業Scrum),Ken Schwaber
  • Scale Scrum,Jeff Sutherland,Alex Brown
  • 企業Scrum,邁克Beedle
  • Setchu(基於Scrum的輕量級框架),Michael Ebbage的Xscale
  • 敏捷路徑
  • 整體軟件開發

對於所有這些是否有效或者確實符合敏捷開發的定義,存在許多相互矛盾的觀點,而且這仍然是一個積極和正在進行的研究領域。

當敏捷軟件開發應用於分佈式環境(團隊分散在多個業務地點)時,通常稱為分佈式敏捷開發。目標是利用每種方法提供的獨特優勢。分佈式開發允許組織通過戰略性地在全球不同地區建立團隊來構建軟件,實際上是全天候建立軟件(或稱為「跟隨太陽模式」)。另一方面,敏捷開發在響應變化時提供了更高的透明度,持續的反饋和更大的靈活性。

對比其他的方法

編輯

敏捷方法有時候被誤認為是無計劃性和紀律性的方法,實際上更確切的說法是敏捷方法強調適應性而非預見性。

適應性的方法集中在快速適應現實的變化。當專案的需求起了變化,團隊應該迅速適應。這個團隊可能很難確切描述未來將會如何變化.

對比迭代方法

編輯

相比迭代式開發兩者都強調在較短的開發周期提交軟件,敏捷方法的周期可能更短,並且更加強調隊伍中的高度協同運作。

對比瀑布式開發

編輯

兩者沒有很多的共同點,瀑布模型是最典型的預見性的方法,嚴格遵循預先計劃的需求、分析、設計、編碼、測試的步驟順序進行。步驟成果作為衡量進度的方法,例如需求規格,設計文件,測試計劃和程式碼審閱等等。

瀑布式的主要的問題是它的嚴格分級導致的自由度降低,專案早期即作出承諾導致對後期需求的變化難以調整,代價高昂。瀑布式方法在需求不明並且在專案進行過程中可能變化的情況下基本是不可行的。

相對來講,敏捷方法則在幾周或者幾個月的時間內完成相對較小的功能,強調的是能將儘早將儘量小的可用的功能交付使用,並在整個專案周期中持續改善和增強。

有人可能在這樣小規模的範圍內的每次迭代中使用瀑布式方法,另外的人可能將選擇各種工作並列進行,例如極限編程

敏捷方法的適用性

編輯

在敏捷方法其獨特之處以外,他和其他的方法也有很多共同之處,比如迭代開發,關注互動溝通,減少中介過程的無謂資源消耗。通常可以在以下方面衡量敏捷方法的適用性:從產品角度看,敏捷方法適用於需求萌動並且快速改變的情況,如系統有比較高的關鍵性、可靠性、安全性方面的要求,則可能不完全適合;從組織結構的角度看,組織結構的文化、人員、溝通則決定了敏捷方法是否適用。跟這些相關聯的關鍵成功因素有:

  • 組織文化必須支援談判
  • 人員彼此信任
  • 人少但是精幹
  • 開發人員所作決定得到認可
  • 環境設施滿足成員間快速溝通之需要

最重要的因素恐怕是專案的規模。規模增長,面對面的溝通就愈加困難,因此敏捷方法更適用於較小的隊伍,40、30、20、10人或者更少。大規模的敏捷軟件開發尚處於積極研究的領域。

另外的問題是專案初期的大量假定或者快速收集需求可能導致專案走入誤區,特別是客戶對其自身需要毫無概念的情況下。與之類似,人之天性很容易造成某個人成為主導並將專案目標和設計引入錯誤方向的境況。開發者經常能把不恰當的方案授予客戶,並且直到最後發現問題前都能獲得客戶認同。雖然理論上快速互動的過程可以限制這些錯誤的發生,但前提是要有效的「負反饋」,否則錯誤會迅速膨脹,並在最終提交時造成極大返工。

用於敏捷開發團隊的專案管理工具

編輯

已經有一些專案管理工具用於敏捷開發,可以用它們來幫助規劃,跟蹤,分析和整合工作。 這些工具在敏捷開發中扮演的重要的角色,也是知識管理的一種方法。

通常包括:版本控制整合,進度跟蹤,工作分配,整合發佈和迭代規劃,討論區和軟件缺陷的報告和跟蹤。

方法列表

編輯

目前列入敏捷方法的有:

  • 軟件開發之韻,Software Development Rhythms
  • 敏捷數據庫技術,AD/Agile Database Techniques
  • 敏捷建模,AM/Agile Modeling
  • 自適應軟件開發,ASD/Adaptive Software Development
  • 水晶方法,Crystal
  • 特性驅動開發,FDD/Feature Driven Development
  • 動態系統開發方法,DSDM/Dynamic Systems Development Method
  • 精益軟件開發,Lean Software Development
  • AUP(Agile Unified Process)
  • Scrum
  • XBreed
  • 極限編程,(Extreme Programming)
  • 探索性測試
  • ATDD

敏捷技術

編輯

參考文獻

編輯
  1. ^ Collier, Ken W. Agile Analytics: A Value-Driven Approach to Business Intelligence and Data Warehousing. Pearson Education. 2011: 121 ff. ISBN 9780321669544. What is a self-organizing team? 
  2. ^ Beck, Kent M.; Beedle, Mike; Bennekum, Arie van; Cockburn, Alistair; Cunningham, Ward; Fowler, Martin; Grenning, James; Highsmith, Jim; Hunt, Andy; Jeffries, Ron; Kern, Jon; Marick, Brian; Martin, R. C.; Mellor, Steve J.; Schwaber, Ken; Sutherland, Jeff; Thomas, Dave. Manifesto for Agile Software Development. S2CID 109006295. 
  3. ^ What is Agile Software Development?. Agile Alliance. 8 June 2013 [4 April 2015]. (原始內容存檔於2015-11-27). 
  4. ^ Rally. Agile With a Capital "A" Vs. agile With a Lowercase "a". 2010 [September 9, 2015]. (原始內容存檔於5 January 2016). 
  5. ^ Kent Beck; James Grenning; Robert C. Martin; Mike Beedle; Jim Highsmith; Steve Mellor; Arie van Bennekum; Andrew Hunt; Ken Schwaber; Alistair Cockburn; Ron Jeffries; Jeff Sutherland; Ward Cunningham; Jon Kern; Dave Thomas; Martin Fowler; Brian Marick. Manifesto for Agile Software Development. Agile Alliance. 2001 [14 June 2010]. (原始內容存檔於2011-02-23). 
  6. ^ Which is better – Kanban or Scrum?, 4 March 2016 [2023-02-28], (原始內容存檔於2023-03-06) 
  7. ^ 敏捷軟體開發宣言. [2017-12-20]. (原始內容存檔於2017-12-30) (中文(繁體)). 
  8. ^ 敏捷软件开发宣言. [2017-12-20]. (原始內容存檔於2017-12-08) (中文(簡體)). 
  9. ^ 敏捷宣言背後的原則. [2011-02-01]. (原始內容存檔於2010-12-16) (中文(繁體)). 
  10. ^ 敏捷宣言遵循的原则. [2011-02-01]. (原始內容存檔於2011-03-06) (中文(簡體)). 

延伸閱讀

編輯

外部連結

編輯