是時候瞭解下軟體開發的生命周期了!

来源:https://www.cnblogs.com/ziph/archive/2020/06/06/13056286.html
-Advertisement-
Play Games

軟體開發的生命周期 既然我們以後從事的工作時軟體開發,那麼我們就要對軟體開發的流程先做瞭解,畢竟要從娃娃抓起。早點瞭解軟體開發流程,也就有了軟體開發的思想與動力。 軟體開發的生命周期 問題定義 問題定義 是軟體定義時期的第一個階段。作為軟體的開發者,在這個階段必須弄清用戶“需要電腦解決什麼問題”。 ...


軟體開發的生命周期

既然我們以後從事的工作時軟體開發,那麼我們就要對軟體開發的流程先做瞭解,畢竟要從娃娃抓起。早點瞭解軟體開發流程,也就有了軟體開發的思想與動力。


軟體開發的生命周期
軟體開發的生命周期

問題定義

問題定義 是軟體定義時期的第一個階段。作為軟體的開發者,在這個階段必須弄清用戶“需要電腦解決什麼問題”。如果在問題尚未明確的情況下就試圖解決這個問題,那麼就會白白浪費時間和精力,結果也毫無意義。所以總結起來問題的定義也是起到了十分重要的位置!

可行性分析

軟體可行性分析 是通過對項目的市場需求、資源供應、建設規模、工藝路線、設備選型、環境影響、資金籌措、盈利能力等方面的研究,從技術、經濟、工程等角度對項目進行調查研究和分析比較,並對項目建成以後可能取得的財務、經濟效益及社會環境影響進行科學預測,為項目決策提供公正、可靠、科學的軟體咨詢意見。

  1. 技術角度: 通俗易懂點根據公司的技術來判定項目是否可行,比如:給定時間是否可以完成項目、軟體的質量、軟體的生產率。
  2. 經濟角度: 根據公司資金周轉來判斷項目是否可以完成,這裡不只是資金問題,還需要考慮成本、收益、長期盈利與短期盈利。短期利益容易把握,風險較低;長遠利益難以把握,風險較大。
  3. 社會因素: 根據項目的社會因素來評判項目是否可以做,比如:社會因素的可行性、法律可行性、社會推廣可行性、使用可行性。想必大家都明白,現在的有些軟體開發會出現抄襲、侵權的現象吧,所以在可行性分析中應當具有相關法律聲明。例如:該系統的開發將不會侵犯任何個人、集體、國家的利益,也不會違反國家的政策與法律。
  4. 文檔: 《可行性分析文檔》

需求分析

需求分析 也稱為軟體需求分析、系統需求分析或需求分析工程等,是開發人員經過深入細緻的調研和分析,準確理解用戶和項目的功能、性能、可靠性等具體要求,將用戶非形式的需求表述轉化為完整的需求定義,從而確定系統必須做什麼的過程。

  1. 功能需求: 功能性需求即軟體必須完成哪些事,必須實現哪些功能,以及為了向其用戶提供有用的功能所需執行的動作。開發者需要與用戶溝通交流,並核實用戶需求,從幫助用戶完成事務的角度上充分描述外部行為,形成說明書。
  2. 非功能用戶需求: 非功能性需求主要包含軟體使用時對性能方面的要求、所依賴的運行環境。軟體設計必須遵循的相關標準、規範、用戶界面設計的具體細節、未來可能的擴充方案等。
  3. 設計約束: 設計限制條件,通常是對一些設計或實現方案的約束說明。
  4. 文檔: 《軟體需求規格說明書》

需求分析階段的工作,可以分為四個方面:問題識別、分析與綜合、制訂規格說明、評審。

  1. 問題識別: 就是從系統角度來理解軟體,確定對所開發系統的綜合要求,並提出這些需求的實現條件,以及需求應該達到的標準。這些需求包括:功能需求(做什麼)、性能需求(要達到什麼指標)、環境需求(如機型、操作系統等)、可靠性需求(不發生故障的概率)、安全保密需求、用戶界面需求、資源使用需求(軟體運行是所需的記憶體、CPU等)、軟體成本消耗與開發進度需求、預先估計以後系統可能達到的目標。
  2. 分析與綜合: 逐步細化所有的軟體功能,找出系統各元素間的聯繫,介面特性和設計上的限制,分析他們是否滿足需求,剔除不合理部分,增加需要部分。最後綜合成系統的解決方案,給出要開發的系統的詳細邏輯模型(做什麼的模型)。
  3. 制訂規格說明書: 即編製文檔,描述需求的文檔稱為軟體需求規格說明書。請註意,需求分析階段的成果是需求規格說明書,向下一階段提交。
  4. 評審: 對功能的正確性,完整性和清晰性,以及其它需求給予評價。評審通過才可進行下一階段的工作,否則重新進行需求分析。

概要設計

概要設計 的主要任務是把需求分析得到的系統擴展用例圖轉換為軟體結構和數據結構。設計軟體結構的具體任務是:將一個複雜系統按功能進行模塊劃分、建立模塊的層次結構及調用關係、確定模塊間的介面及人機界面等。數據結構設計包括數據特征的描述、確定數據的結構特性、以及資料庫的設計。

  1. 技術選型: 通過需求分析結果來判斷使用什麼技術來完成項目,構建技術架構,例如:使用SSM+JSP技術等
  2. 平臺搭建: 選擇項目搭建所需平臺技術,例如:JDK1.8、tomact8.5、MySQL5.X等
  3. 資料庫設計: 實體、數據項、三範式、E-R圖等
  4. 功能流程設計: 以模塊為單位進行流程圖的設計
  5. UI設計: UI設計,簡稱界面設計。是指對軟體的人機交互、操作邏輯、界面美觀的整體設計。 UI設計師完成
  6. 文檔: 《資料庫設計說明書》《概要設計說明書》

詳細設計

詳細設計 ,是軟體工程中軟體開發的一個步驟,就是對概要設計的一個細化,就是詳細設計每個模塊實現演算法,所需的局部結構。在詳細設計階段,主要是通過需求分析的結果,設計出滿足用戶需求的軟體系統產品。傳統軟體開發方法的詳細設計主要是用結構化程式設計法。

  1. 創建資料庫、表、表關係等
  2. 設計每個功能的實現步驟:例如:功能編號、功能名稱、功能描述、輸入項(用戶輸入數據的說明)、數據處理(程式對用戶輸入的數據的處理流程)、輸出項(展示給用戶的視圖界面及數據)等
  3. 文檔: 《詳細設計說明書》

編寫編碼

編碼通俗易懂來說,就是需要寫代碼了!對產品根據功能和技術架構來實現功能開發、單元測試、功能測試等

產品測試

軟體測試 ,描述一種用來促進鑒定軟體的正確性、完整性、安全性和質量的過程。軟體測試的經典定義是:在規定的條件下對程式進行操作,以發現程式錯誤,衡量軟體質量,並對其是否能滿足設計要求進行評估的過程。

  1. 靜態測試: 對軟體代碼的靜態分析測驗,過程應用數據較少,可以通過人工或機器輔助測試

  2. 動態測試: 檢測軟體運行中出現的問題,較靜態測試方式相比,其被稱為動態的原因即為其測試方式主要依賴程式的運用,主要為檢測軟體中動態行為是否缺失、軟體運行效果是否良好。

  3. 功能測試(黑盒測試): 通過數據輸入觀察數據輸出,檢查軟體內部功能是否正常,數據是否一致等等。

  4. 性能測試(白盒測試): 原理為根據軟體內部應用、源代碼等對產品內部工作過程進行調試。測試過程中常將其與軟體內部結構協同展開分析,最大優點即為其能夠有效解決軟體內部應用程式出現的問題,測試過程中常將其與黑盒測試方式結合

  5. 系統集成測試: 在單元測試的基礎上,將所有模塊按照設計要求(如根據結構圖)組裝成為子系統或系統,進行集成測試。一些模塊雖然能夠單獨地工作,但並不能保證連接起來也能正常的工作。一些局部反映不出來的問題,在全局上很可能暴露出來。

  6. 壓力測試: 軟體壓力測試是一種基本的質量保證行為。壓力測試是給軟體不斷加壓,強制其在極限的情況下運行,觀察它可以運行到何種程度,從而發現性能缺陷,是通過搭建與實際環境相似的測試環境,通過測試程式在同一時間內或某一段時間內,向系統發送預期數量的交易請求、測試系統在不同壓力情況下的效率狀況,以及系統可以承受的壓力情況。然後做針對性的測試與分析,找到影響系統性能的瓶頸,評估系統在實際使用環境下的效率情況,評價系統性能以及判斷是否需要對應用系統進行優化處理或結構調整。並對系統資源進行優化。

壓力測試可以分為負載測試、併發性能測試、疲勞強度測試

負載測試: 通過增加系統負載來測試系統性能的變化趨勢。並最終確定系統的最大負載不能超過某個值,以確保為用戶提供最大的服務還保證了系統性能。

併發性能測試: 通過逐漸增加用戶量和用戶的併發訪問量,直到系統遇到瓶頸或者不能正常運轉,綜合分析交易執行指標與資源監控指標。

疲勞強度測試: 構建系統穩定運行情況下能夠支持的最大併發度與日常運轉。

軟體的性能可以通過響應時間、併發用戶數、吞吐量、資源利用率等性能指標來衡量。

響應時間: 是指用戶從客戶端發出請求到接收完伺服器返回結果的整個過程所需花費的時間,包含網路傳輸時間以及伺服器處理時間。從用戶角度來看,響應時間應該從客戶端電腦處理用戶操作併發出請求到客戶端程式收到伺服器端返回結果並顯示出來的時間。

併發用戶數: 是指在一定時間內,某一時刻同時與伺服器進行會話操作的用戶數,併發用戶數的類型包括:系統用戶數、同時線上用戶數,業務併發用戶數。

吞吐量: 是指單位時間內,系統處理用戶的請求數或頁面數量,可以直接反映出軟體的承載能力。一般來說,利用每秒鐘的請求數或頁面數量衡量吞吐量;從業務的角度來看,也可以用每天的訪問人數或每小時處理的業務數來衡量。

資源利用率: 是指系統資源(CPU、記憶體)的利用率,通常用資源的實際使用量與總的資源可用量比值來衡量,包括網路、操作系統、資料庫等方面。

產品交付

項目部署、用戶培訓、交付協議款、後期保證協議內期限的產品維護等

總結

軟體開發流程可以分為這幾大步驟:

  • 問題定義
  • 可行性分析
  • 需求分析
  • 概要設計
  • 詳細設計
  • 編寫代碼
  • 產品測試
  • 產品交付

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 對於python中pip安裝庫文件超時問題 找了好多方法,發現更換安裝源最適合我 方案一:對於比較小的庫,可以延時處理 pip --default-timeout=100 install -U pip pip --default-timeout=100 install 第三方庫名方案二:更換安裝源 ...
  • https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1591472927710&di=fdd3da90a98ed401c87ddaf96fdbade2&imgtype=0&src=http%3A%2F%2F5b098... ...
  • 一 安裝jdk zookeeper是採用java開發的,所以需要依賴jdk環境,我們需要先安裝jdk,最便捷的方式就是採用yum,但是yum的官方源速度很慢,我們可以先更換yum源; #備份初始源 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos ...
  • 內容不涉及演算法相關內容,paxos演算法,zab協議等網路上已經有很多優秀的文章,這裡就不獻醜了 什麼是Zookeeper ZooKeeper是分散式應用程式的分散式協調服務,是Google的Chubby一個開源的實現,是Hadoop和Hbase的重要組件。它是一個為分散式應用提供一致性服務的軟體,提 ...
  • 出現這種問題,我這裡遇到的原因是因為上一次查詢的結果集沒有釋放完全,導致查詢失敗 此時的錯誤內容是:Commands out of sync; you can't run this command now 該錯誤內容由mysql_error(conn)語句輸出。 如果你在上次查詢時忘了調用mysql ...
  • 方法引用 在使用Lambda表達式的時候,我們實際上傳遞進去的代碼就是一種解決方案:那參數做操作 弱國我們在Lambda中蘇哦指定的操作方案,已經有地方存在相同方案,那是否還有必要再寫重覆邏輯呢,答案肯定時沒有必要。 我們通過方法引用使用已經存在的方案 public interface PrintT ...
  • import pandasexcel=pandas.read_excel('現代徵信學.xlsx',index_col='列名',header=None) #header預設為0,指讀取第幾行,0代表第一行excel.columns=['Id','title','hh','uei','t'] #重新 ...
  • Java生鮮電商平臺-生鮮小程式首頁系統功能詳解(小程式/APP) 說明:對於一個成熟的生鮮小程式而言,首頁至關重要,下麵我就列舉,我們系統中的首頁的功能,本文只是簡單的介紹下,以達到拋磚引玉的作用,希望對大家有點幫助。 QQ:137071249 共同學習QQ群:793305035 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...