0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

敏捷or瀑布:你還在糾結嗎?

汽車ECU開發(fā) ? 來源:汽車ECU開發(fā) ? 2023-06-19 09:32 ? 次閱讀

工程開發(fā)的本質與瀑布模型

自然界的系統(tǒng)大致可以分為兩種主要的類型,一種是自然形成的,一種是人工制造的。我們在這里只關注人工制造的系統(tǒng)。因為其涉及到工程開發(fā),所以,可以將其稱為:工程系統(tǒng)(Engineering System)。工程系統(tǒng)實現(xiàn)的過程就是工程開發(fā)的過程。

所有的工程開發(fā),起點都始于需求。無論是一部手機,還是一架飛機,甚至是一棟建筑,它們被開發(fā)出來的目的都是為了滿足某種需求。因為,如果這些系統(tǒng)不能滿足某種特定的需求,就不會有人去花費時間、金錢和體力去實現(xiàn)它。

當需求基本確定了之后,接下來要做的就是進行設計。此時需要做的是確定這個系統(tǒng)使用在什么樣的環(huán)境內,有哪些主要的組成部分(組件),它們之間是怎么連接(結構)的,需要滿足哪些標準(原則)等。這個相當于系統(tǒng)架構的設計,或者是系統(tǒng)的詳細設計。如果系統(tǒng)復雜到需要多個人參與設計,那么架構設計就是必不可少的。負責設計架構的人把系統(tǒng)分為多個子系統(tǒng),并規(guī)定好每個子系統(tǒng)的邊界和接口等一系列要求,再由相應的人進行更詳細的設計。

設計完成之后,就是開始實現(xiàn)了。這個時候,施工隊入場了,不同的人負責不同的工作。對于電子產品來說,要有軟件、硬件工程師。對于建筑來說,需要泥瓦工、水電、油漆等工種。不論產品如何,這個階段大家都是按照上面的設計來進行實現(xiàn)。

施工完成后,需要做的是驗收。不管產品是哪一種,驗收都可以分為兩類:驗證(Verification)和確認(Validation)。驗證活動檢查的是產品是不是按照設計實現(xiàn)了,確認檢查的是產品是不是確實是用戶想要的。對于建筑物來說,設計的時候是10層樓,結果蓋成了9層樓,那么就是不合格的,因為不符合設計。可是如果設計的時候就注明了每層樓高2米,而客戶需要的是3米的層高,那么即使驗證合格了,確認環(huán)節(jié)也不合格。

在驗收結束后,產品就可以交付給用戶使用了。在一段時間內,產品的提供方還需要持續(xù)的對產品進行維護,產品出了問題時,產品的提供方就需要及時給解決。這個過程相當于售后的質保。

以上的過程就可以采用瀑布模型(Waterfall Model)進行表示。

3b3b7670-0e3b-11ee-962d-dac502259ad0.png

瀑布模型的發(fā)展經歷了幾個階段,1956年在一篇關于軟件開發(fā)的論文中首次提到。在接下來的幾十年里,它被不斷完善,最后被美國國防部采用,作為承包商需要遵循的標準。瀑布模型描述了一種按照一定順序處理開發(fā)過程步驟的方法。

瀑布模型中,所有的工作都是順序的,是一層層流下來的,像瀑布的水流一樣,是單向的。純粹的瀑布模型的本質是,在進入下一個步驟之前,必須完全完成本步驟的所有任務??雌饋磉壿嫼芡?,但實際應用的時候卻可能會遇到很多問題。因為,需求(Requirement)可能不全或有錯誤,設計(Design)的過程中可能會出錯,實現(xiàn)(Implementation)也可能會出錯,從而導致理想的瀑布模型會不適用于很多復雜的場景。如果完全按照這種模式開發(fā),就可能出現(xiàn)不斷重啟所有環(huán)節(jié)的情況。

實際的開發(fā)過程中,往往很少完全按照瀑布模型開展,產品一般都要經歷多次迭代。我們所熟悉的水果手機也不是在一出現(xiàn)就這么NB的,而是從1,2,3,4……一代代發(fā)展而來的。

3b63ef4c-0e3b-11ee-962d-dac502259ad0.png

從上面的討論我們可以看出,所有的工程開發(fā)都是從需求開始的,要經歷需求-設計-實現(xiàn)-驗證-維護的階段。瀑布模型反映的就是這個本質。

敏捷開發(fā)

開發(fā)背景下的敏捷(Agile)一詞最早出現(xiàn)在2001年的猶他州的雪鳥會議上。在這場傳奇性的會議上,一些軟件人士聚集在一起,討論軟件編程的革命性方法。雖然那時極限編程(與Scrum相當相似)已經建立,但許多人仍然對沉重的軟件開發(fā)過程和非常長的開發(fā)時間感到沮喪。復雜的系統(tǒng)如航天飛機的開發(fā)時間超過了20年。

猶他州的那些人創(chuàng)造了敏捷宣言 [ https://agilemanifesto.org/],描述了敏捷開發(fā)的主要原則,但其根源可以追溯到20世紀60年代人們開始嘗試快速開發(fā)之時。Scrum這種最流行的敏捷方法之一,也是在1995年初開發(fā)的。

3b716d48-0e3b-11ee-962d-dac502259ad0.png

《敏捷宣言》描述了12條原則,如下:

l 客戶的滿意是最優(yōu)先的。

l 在整個開發(fā)周期中,需求可以被改變。

l 在較短的周期內頻繁地交付工作軟件。

l 開發(fā)人員和業(yè)務人員需要有很好的聯(lián)系。

l 能夠對開發(fā)人員產生信任和激勵的支持性環(huán)境是關鍵。

l 自組織的團隊是高質量的關鍵。

l 團隊本身定期反思改進自己。

l 面對面的會議和同地辦公始終是首選。

l 可以工作的軟件是衡量成功的主要標準。

l 卓越的技術和強大的設計是持續(xù)關注的焦點。

l 簡潔性是必不可少的。

l 可持續(xù)發(fā)展和持續(xù)的步伐是敏捷的本質。

敏捷是項目管理和開發(fā)過程的混合物。Scrum以及Kanban可以被認為是純粹的項目管理方法。其他的敏捷方法,如測試驅動開發(fā)、結對編程和持續(xù)集成,則是在軟件開發(fā)或是質量保證方面。

敏捷開發(fā)中,與軟件有關的和與人有關的主題被很好的整合了。這就是敏捷的關鍵因素之一:工程師和他們的合作是成功的關鍵。對于那些習慣于以孤立的方式工作而不合作的人來說,他們無法通過Scrum這樣的項目管理方式來管理。

敏捷開發(fā)方法的主要特點是通過小型團隊的合作來實現(xiàn)快速迭代。但仍然遵循著需求、設計、實現(xiàn)、驗證的流程,這一點與瀑布式并無不同。與瀑布式開發(fā)不同的是,它的每一輪迭代的周期要小得多,通常以周為單位。它們的創(chuàng)建是為了快速交付并從用戶或利益相關者那里獲得早期反饋。這樣做的好處是,產品能更快地到最終用戶手中,而且反饋也能更快地回到開發(fā)團隊中。團隊致力于根據反饋和優(yōu)先級迅速調整方向,所以上述所有問題都通過短的反饋周期和透明度來解決。最后,團隊致力于持續(xù)改進。每個沖刺結束時都有一個回顧會,每個人都有機會發(fā)言,討論下一輪可能進行的改進。

敏捷還是瀑布?

究竟應該采用哪種開發(fā)方式?這個問題就像一個人問:應該吃蔬菜還是肉呢?如果籠統(tǒng)的回答,就只能是:看情況了。

不同的公司、不同的項目有不同的特點和要求,無法一概而論。簡單而言,敏捷更適合那種需要不斷快速試錯的項目,而且對團隊能力的要求很高。當需求不清楚或實現(xiàn)方案不清楚的時候,采用敏捷方式可以快速交付原型產品,得到客戶的反饋,并能夠讓團隊聚焦在高優(yōu)先級的任務上,從而提升交付效率。

然而,對于那些需求清晰、團隊規(guī)模大的項目,敏捷則并不一定能夠發(fā)揮很好的作用。這種情況下,如果有很好的架構設計,每個模塊或子系統(tǒng)的接口、邊界和需求都清晰的時候,每個子團隊完全可以按部就班的開展工作,每個人都有明確的職責和角色,也無需每兩周就交付一個版本,只需要按照既定的里程碑工作即可。此時,傳統(tǒng)的類似瀑布式的開發(fā)可能更為合適。尤其是在那些增量型的項目中:很多人在一個平臺上修修補補,只要大家能夠各司其職,有人在統(tǒng)一管理也就沒有問題了。

敏捷在很大程度上還涉及團隊精神、團隊授權和合作。如果一個團隊中的氛圍不好,也沒有得到充分授權,那么采用敏捷也無法提升效率。另外,假如每個工程師都需要同時負責多個項目的事情,敏捷也沒有辦法開展起來。

在有些人的眼中,瀑布就代表著落后,敏捷就代表著先進,這個未免有失偏頗。如同青菜與肉、跑車與拖拉機一樣,沒有好壞,只有適合與否。而且,我還從沒有看到過那個項目是完全按照瀑布式開發(fā)的。所有的項目都是按照計劃在最終版發(fā)布前有多個過程版本發(fā)布的,這也就是說,實際工程開發(fā)中也是按照敏捷的思想在開展的,只不過形式不同,迭代的周期不同而已。

當你的軟件項目有幾十個開發(fā)人員,產品規(guī)模遠大于一個團隊所能開發(fā)的規(guī)模,而且還需要快速地進行交付,那該怎么辦?業(yè)界已經定義了一些方法來將Scrum擴展到更大的軟件產品。擴展的Scrum方法包括Nexus、LeSS(Large Scale Scrum)和SAFe(Scaled Agile Framework)?;镜乃枷胧牵盒〉拈_發(fā)團隊向更高層次的團隊交付,以此類推,直到完整的產品完成??赡苄枰恍┬碌囊?guī)則、工件、團隊和會議。

在古老的汽車行業(yè),雖然軟件越來越重要,但軟件不是汽車中的唯一組件,軟件還需要與硬件和機械相結合才能有用武之地,軟件的開發(fā)也要匹配整車開發(fā)的時間線和SOP節(jié)點的要求。

總結

1.開發(fā)的本質都是要從需求開始,經歷需求-設計-實現(xiàn)-驗證-維護的階段。只不過不同的項目或不同的組織選擇了不同的迭代周期和開發(fā)方式。不同復雜度的產品經歷的迭代輪次不同,開發(fā)周期也不同,但目的都是相同的:滿足需求,交付系統(tǒng)!

2.如果從大的時間尺度來看,所有被持續(xù)更新的工程系統(tǒng)都是逐漸增長起來的,這與敏捷的思想很接近。產品都是從簡單到復雜的,功能是逐漸增長的,大樓也是一層的蓋起來的,汽車在剛剛出現(xiàn)的時候與現(xiàn)在所看到的完全不同,Windows操作系統(tǒng)也是逐漸演進的,控制器的軟件也是演進而來的。

3.Kanban和Sprint等都是一種工具或方法,而工具和方法都必然有自己的適用范圍,在不同的情況下,要靈活使用,沒有萬能的工具。

4.選擇敏捷還是瀑布,需要考慮的點很多,至少包括:團隊規(guī)模,項目規(guī)模,開發(fā)需求是否明確,人員能力,人員穩(wěn)定性,團隊氛圍,項目是否需要持續(xù)維護等。

5.當需求明確,技術方案也明確,也就是比較簡單的時候,使用瀑布。當需求不明確或技術方案不明確,使用敏捷。

6.敏捷的好處是減少試錯成本,快速交付,不斷優(yōu)化開發(fā)過程(資源、能力、流程等)。

7.敏捷也是一種流程,而非沒有流程。

8.敏捷與瀑布并非對立的,如同青菜與肉一樣,兩者的適度結合才能有更好地產出。敏捷是一種思想和意識,而非教條。

最后,想說的兩點是:

1.如果你的項目不是一錘子買賣,也就是還需要不斷迭代升級和維護,那么還是老老實實寫好文檔。這與敏捷還是瀑布無關,因為你的團隊不可能沒有人員變動,人員也不可能永遠都清楚地記得自己幾年前做了什么。

2.看清事物本質就不會迷茫,盲目的采用敏捷并不能保證效率一定高。瀑布還是敏捷,本質上都是一種方式,靈活的在不同的時期采用不同的方式才是明智之舉。固執(zhí)的認為某種方式可以普適于所有情況,就是守株待兔、刻舟求劍、枉曲直湊!

end

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 編程
    +關注

    關注

    88

    文章

    3623

    瀏覽量

    93797
  • 模型
    +關注

    關注

    1

    文章

    3255

    瀏覽量

    48901
  • 系統(tǒng)
    +關注

    關注

    1

    文章

    1017

    瀏覽量

    21369

原文標題:敏捷or瀑布:你還在糾結嗎?

文章出處:【微信號:eng2mot,微信公眾號:汽車ECU開發(fā)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    用labview怎么顯示一個信號的瀑布

    RT,要求瀑布圖實時更新,信號的頻率和幅值都有了,要怎么顯示呢?
    發(fā)表于 01-29 19:09

    還在為沒有開發(fā)板而煩惱嗎還在為沒有開發(fā)板而煩惱嗎

    還在為沒有開發(fā)板而煩惱
    發(fā)表于 09-06 17:18

    labview設計瀑布

    大家有了解labview設計瀑布圖的嘛,給提點意見啊
    發(fā)表于 03-26 14:59

    求助瀑布圖程序

    誰有瀑布圖的程序啊,求救,不裝聲音與振動模塊的
    發(fā)表于 04-03 10:49

    大兄弟啊,還在擼嗎?

    `大兄弟啊,還在擼嗎?來,咱來嘮嘮為啥妹子只跟你說呵呵去洗澡?為啥陣營女神從來不找你千里送?為啥酒吧里姑娘視線都跳過?以為是丑?天真
    發(fā)表于 04-07 14:17

    labview幫助中瀑布圖理解

    labview幫助中瀑布圖的程序框圖見附件。問題1 :為什么X-Z下和Y-Z下的圖形不同,輸出的矩陣中值見圖片2,數值和Y-Z中的數值并不對應。麻煩大神給講解下!不甚感激!??!
    發(fā)表于 05-19 20:16

    還在用j-link?OUT了,CMSIS-DAP值得擁有

    還在的盜版J-link經常丟固件爾煩惱嗎?還在苦苦尋覓一款物美價廉的仿真器嗎?是否用過
    發(fā)表于 06-23 14:11

    阿里巴巴敏捷研發(fā)的探索與實踐

    摘要: 今天敏捷了嗎?敏捷產品開發(fā)提倡快速迭代、小步快跑,以便更靈活地應對變化,目前逐漸演變?yōu)樾袠I(yè)潮流。阿里巴巴內部也在不斷進行敏捷實踐。點此查看原文:http
    發(fā)表于 03-07 17:26

    敏捷開發(fā)方法知識

    敏捷是一種思想,如何用敏捷的思想來進行生產或開發(fā),又有很多敏捷方法。關于敏捷開發(fā)方法的知識,我搜集整理了一下,大致如下:
    發(fā)表于 07-17 08:18

    鐘情瀑布屏,華為新機有望應用

    華為Mate30系列會采用瀑布屏。
    的頭像 發(fā)表于 08-05 14:27 ?2778次閱讀

    vivo NEX新品曝光采用了曲面瀑布屏設計擁有像瀑布一樣的視覺效果

    據悉,瀑布屏是一種新的全面屏形態(tài),它指的是即將流行的大曲率顯示屏,其最大特色是曲面屏的左右兩側具備像瀑布一樣的視覺效果。
    發(fā)表于 08-14 10:04 ?806次閱讀

    對被動元件參數感到過糾結嗎?

    您是否曾因為被動元件的第二級或第三級參數、它們的規(guī)格或數值的變異與改變等相關問題而感到意外或甚至因此而“糾結”?
    的頭像 發(fā)表于 01-16 17:36 ?2418次閱讀

    瀑布敏捷的軟件開發(fā)模式歸納盤點

    瀑布模型是比較傳統(tǒng)一種開發(fā)模式,特別是在2B的傳統(tǒng)企業(yè),包括ERP,MES,WMS,CRM,OA,IBMS等系統(tǒng)當中可以經常見到他們的影子。
    的頭像 發(fā)表于 09-13 14:30 ?810次閱讀

    汽車裝什么車燈好?還在糾結嗎?

    點擊藍字關注我們SUBSCRIBEtoUS首先讓我們先來了解一下這三種車燈:鹵素燈是最常見的光源。也是大家常說的蠟燭燈。因為近年氙氣燈、LED燈發(fā)展迅猛,鹵素燈的亮度已經遠遠不能滿足人們對燈光亮度的需求。這點和現(xiàn)代人視力下降有一定的關系,夜晚行車對照明亮度要求越來越高。氙氣燈是前幾年豪華車型或者高配車型必備的光源。亮度明顯比鹵素燈高一截,而功率確降低1/3左
    的頭像 發(fā)表于 09-15 11:11 ?1271次閱讀
    汽車裝什么車燈好?<b class='flag-5'>你</b><b class='flag-5'>還在</b><b class='flag-5'>糾結</b>嗎?

    還在使用傳統(tǒng)架構的DC-DC轉換器嗎?

    還在使用傳統(tǒng)架構的DC-DC轉換器嗎?
    的頭像 發(fā)表于 12-04 17:26 ?948次閱讀
    <b class='flag-5'>你</b><b class='flag-5'>還在</b>使用傳統(tǒng)架構的DC-DC轉換器嗎?