服務近2000家企業(yè),依托一系列實踐中打磨過的技術(shù)和產(chǎn)品,根據(jù)企業(yè)的具體業(yè)務問題和需求,針對性的提供各行業(yè)大數(shù)據(jù)解決方案。
如何做好應用軟件開發(fā)?
來源:未知 時間:2018-34-10 瀏覽次數(shù):226次
如何做好應用軟件開發(fā)?應用軟件是指用于商業(yè),生活方面的軟件開發(fā),其特點是對于技術(shù)要求低于軟件實用價值,強調(diào)軟件的應用性和可用性,強調(diào)用戶體驗,做引用軟件開發(fā)的公司很多,應用軟件類型也很多,但是大部分軟件功能完善,交付用戶后無法使用或不能完全滿足用戶使用,據(jù)行業(yè)數(shù)據(jù)統(tǒng)計,應用軟件開發(fā)成功率只有40%,那么如何做好應用軟件開發(fā),提高開發(fā)成功率呢一、技術(shù)方面選擇適當?shù)能浖_發(fā)方法
在軟件開發(fā)的過程中,軟件開發(fā)方法是關(guān)系到軟件開發(fā)成敗的重要因素。 軟件開發(fā)方法就是軟件開發(fā)所遵循的辦法和步驟,以保證所得到的運行系統(tǒng)和支持的文檔滿足質(zhì)量要求。在軟件開發(fā)實踐中,有很多方法可供軟件開發(fā)人員選擇。軟件開發(fā)方法介紹如下
- 1 結(jié)構(gòu)化開發(fā)方法
結(jié)構(gòu)指系統(tǒng)內(nèi)各組成要素之間的相互聯(lián)系、相互作用的框架。結(jié)構(gòu)化開發(fā)方法強調(diào)系統(tǒng)結(jié)構(gòu)的合理性以及所開發(fā)的軟件的結(jié)構(gòu)的合理性,主要是面向數(shù)據(jù)流的,因此也被稱為面向功能的軟件開發(fā)方法或面向數(shù)據(jù)流的軟件開發(fā)方法。結(jié)構(gòu)化技術(shù)包括結(jié)構(gòu)化分析、結(jié)構(gòu)化設(shè)計和結(jié)構(gòu)化程序設(shè)計三方面內(nèi)容。
- 2 結(jié)構(gòu)化分析的步驟
結(jié)構(gòu)化分析是一種模型的確立活動,就是使用獨有的符號,來確立描繪信息(數(shù)據(jù)和控制)流和內(nèi)容的模型,劃分系統(tǒng)的功能和行為,以及其他為確立模型不可缺少的描述。其基本步驟是:(1)構(gòu)造數(shù)據(jù)流模型:根據(jù)用戶當前需求,在創(chuàng)建實體—關(guān)系圖的基礎(chǔ)上,依據(jù)數(shù)據(jù)流圖構(gòu)造數(shù)據(jù)流模型。(2)構(gòu)建控制流模型:一些應用系統(tǒng)除了要求用數(shù)據(jù)流建模外,通過構(gòu)造控制流圖(CFD),構(gòu)建控制流模型。(3)生成數(shù)據(jù)字典:對所有數(shù)據(jù)元素的輸入、輸出、存儲結(jié)構(gòu),甚至是中間計算結(jié)果進行有組織的列表。目前一般采用CASE的“結(jié)構(gòu)化分析和設(shè)計工具”來完成。(4)生成可選方案,建立需求規(guī)約:確定各種方案的成本和風險等級,據(jù)此對各種方案進行分析,然后從中選擇一種方案,建立完整的需求規(guī)約。
- 3 結(jié)構(gòu)化設(shè)計步驟
結(jié)構(gòu)化設(shè)計是采用最佳的可能方法設(shè)計系統(tǒng)的各個組成部分以及各成分之間的內(nèi)部聯(lián)系的技術(shù),目的在于提出滿足系統(tǒng)需求的最佳軟件的結(jié)構(gòu),完成軟件層次圖或軟件結(jié)構(gòu)圖。其基本步驟如下:
(1)研究、分析和審查數(shù)據(jù)流圖。從軟件的需求規(guī)格說明中弄清數(shù)據(jù)流加工的過程。(2)然后根據(jù)數(shù)據(jù)流圖決定問題的類型。數(shù)據(jù)處理問題有兩種典型的類型:變換型和事務型。針對兩種不同的類型分別進行分析處理。(3)由數(shù)據(jù)流圖推導出系統(tǒng)的初始結(jié)構(gòu)圖。也就是把數(shù)據(jù)流圖映射到軟件模塊結(jié)構(gòu),設(shè)計出模塊結(jié)構(gòu)的上層。(4)利用一些試探性原則來改進系統(tǒng)的初始結(jié)構(gòu)圖,直到得到符合要求的結(jié)構(gòu)圖為止。即在數(shù)據(jù)流圖的基礎(chǔ)上逐步分解高層模塊,設(shè)計中下層模塊,并對軟件模塊結(jié)構(gòu)進行優(yōu)化,最終得到更為合理的軟件結(jié)構(gòu)。(5)描述模塊接口。(6)修改和補充數(shù)據(jù)詞典。(6)制定測試計劃。結(jié)構(gòu)化設(shè)計可以將用數(shù)據(jù)流圖表示的信息轉(zhuǎn)換成程序結(jié)構(gòu)的設(shè)計描述。
- 4 模塊化開發(fā)方法
模塊化程序設(shè)計方法就是把一個待開發(fā)的軟件系統(tǒng)分解成若干可單獨命名和編址的較為簡單的部分,這些可單獨命名和編址的部分稱為模塊。每個模塊分別獨立地開發(fā)、測試,最后再組裝出整個軟件系統(tǒng)。這種方法不僅可以將軟件系統(tǒng)開發(fā)的復雜性在分解過程中降低,便于修改、維護,而且還容易實現(xiàn)同一個系統(tǒng)不同部分的并行開發(fā),從而提高了軟件的生產(chǎn)效率。一般,將用一個名字就可調(diào)用的一段程序稱為“模塊”。在考慮模塊化時,將模塊定義為多大較合適,模塊設(shè)計規(guī)則應如何制定成為關(guān)鍵,下面五條標準可供參考:(1)模塊可分解性:如果一種設(shè)計方法提供了將問題分解成子問題的系統(tǒng)化機制,它就能降低整個系統(tǒng)的復雜性,從而實現(xiàn)一種有效的模塊化解決方案。(2)模塊可組裝性:如果一種設(shè)計方法使現(xiàn)存的設(shè)計模塊能夠被組裝成新系統(tǒng),它就能提供一種不用一切從頭開始的模塊化解決方案。(3)模塊可理解性:如果一個模塊可以作為一個獨立的單位被理解,那么它就易于構(gòu)造和修改。(4)模塊連續(xù)性:如果對系統(tǒng)需求的微小修改只導致對單個模塊而不是對整個系統(tǒng)的修改,則修改引起的副作用就會被最小化。一般來說,對模塊采用耦合和內(nèi)聚兩個準則進行度量。如模塊內(nèi)部具有高內(nèi)聚和模塊間低耦合,那這樣的模塊就具有獨立性,模塊設(shè)計得比較好。
- 5 面向?qū)ο箝_發(fā)方法
面向?qū)ο箝_發(fā)方法是以面向?qū)ο蟪绦蛟O(shè)計語言作為基礎(chǔ)的,其核心思想是利用面向?qū)ο蟮母拍詈头椒檐浖枨蠼⒛P?進行系統(tǒng)設(shè)計,采用面向?qū)ο蟪绦蛟O(shè)計語言進行系統(tǒng)實現(xiàn),對建成的系統(tǒng)進行面向?qū)ο蟮臏y試和維護。如果一個軟件系統(tǒng)是使用這樣4個概念設(shè)計和實現(xiàn)的,則可以認為這個軟件系統(tǒng)是面向?qū)ο蟮?。其基本要點可以概括為:(1)數(shù)據(jù)的抽象,即類與子類的概念及相互關(guān)系。任何客觀的事物和實體都是對象,復雜對象可以由簡單對象組成。(2)數(shù)據(jù)及對它的操作的一體化,即封裝的概念和方法。具有相同數(shù)據(jù)和操作的對象可歸并為一個類,具有封裝性,形成一個包裝;對象是類的一個實例;一個類可以產(chǎn)生很多對象。(3)屬性與操作由父類向子類傳遞,即繼承的概念與方法。類可以派生出子類,繼承能避免共同行為的重復。(4)客觀事物之間的相互關(guān)系用統(tǒng)一的、消息傳遞的方法來描述。目前廣泛使用的面向?qū)ο箝_發(fā)方法包括Booch方法、Rumbaugh方法、Coad和Yourdon方法、Jacobson方法、Wirfs-Brock方法和統(tǒng)一建模方法等。
軟件開發(fā)方法有很多種,在實際軟件開發(fā)中,就涉及到選擇適宜的開發(fā)方法的問題,具體選擇時應綜合考慮以下方面因素:(1) 開發(fā)人員的基本素質(zhì)及經(jīng)驗閱歷。主要看軟件開發(fā)人員是否對該方法有經(jīng)驗或受過專門訓練。(2) 項目進度安排及人員組成情況。要根據(jù)開發(fā)項目的時間限度、人員配備進行選擇。(3) 現(xiàn)有資源狀況??疾楝F(xiàn)有的軟硬件環(huán)境及可使用的CASE工具等。(4) 進行可行性研究。從計劃、組織、管理各個環(huán)節(jié)綜合考慮。選擇軟件開發(fā)方法后,還涉及對所選的開發(fā)方法進行評價。一般說來,可以從以下四個方面來進行評價:(1) 技術(shù)特征:支持各種技術(shù)概念的方法特色。(2) 使用特征:具體開發(fā)時的有關(guān)特色。(3) 管理特征:增強軟件開發(fā)活動管理能力方面的特色。(4) 經(jīng)濟特征:使開發(fā)部門的生產(chǎn)力和軟件質(zhì)量得到提高,產(chǎn)生經(jīng)濟效益的有關(guān)特色。
二.做好需求調(diào)研工作
需求調(diào)研可以說是軟開發(fā)過程中最重要的環(huán)節(jié),有效的需求調(diào)研非常重要,大部分開發(fā)團隊將需求調(diào)研工作看做是一種走過場,或者不能認真對待,需求調(diào)研的核心是掌握用戶核心關(guān)注點,理清整體業(yè)務邏輯,列出軟件開發(fā)的難度并進行驗證
需求分析原則:
軟件開發(fā)方法有很多種,在實際軟件開發(fā)中,就涉及到選擇適宜的開發(fā)方法的問題,具體選擇時應綜合考慮以下方面因素:(1) 開發(fā)人員的基本素質(zhì)及經(jīng)驗閱歷。主要看軟件開發(fā)人員是否對該方法有經(jīng)驗或受過專門訓練。(2) 項目進度安排及人員組成情況。要根據(jù)開發(fā)項目的時間限度、人員配備進行選擇。(3) 現(xiàn)有資源狀況??疾楝F(xiàn)有的軟硬件環(huán)境及可使用的CASE工具等。(4) 進行可行性研究。從計劃、組織、管理各個環(huán)節(jié)綜合考慮。選擇軟件開發(fā)方法后,還涉及對所選的開發(fā)方法進行評價。一般說來,可以從以下四個方面來進行評價:(1) 技術(shù)特征:支持各種技術(shù)概念的方法特色。(2) 使用特征:具體開發(fā)時的有關(guān)特色。(3) 管理特征:增強軟件開發(fā)活動管理能力方面的特色。(4) 經(jīng)濟特征:使開發(fā)部門的生產(chǎn)力和軟件質(zhì)量得到提高,產(chǎn)生經(jīng)濟效益的有關(guān)特色。
二.做好需求調(diào)研工作
需求調(diào)研可以說是軟開發(fā)過程中最重要的環(huán)節(jié),有效的需求調(diào)研非常重要,大部分開發(fā)團隊將需求調(diào)研工作看做是一種走過場,或者不能認真對待,需求調(diào)研的核心是掌握用戶核心關(guān)注點,理清整體業(yè)務邏輯,列出軟件開發(fā)的難度并進行驗證
需求分析原則:
- 完整性原則:需求的全覆蓋,包括組織機構(gòu)及用戶分析、功能需求、性能需求、接口及集成等;
- 正確可行性原則:正確性和可行性:保證需求和業(yè)務人員的目標相聯(lián)系,使用用戶語言和需求模型正確表達用戶需求,同時保證在現(xiàn)有開發(fā)能力和系統(tǒng)環(huán)境下需求的可實現(xiàn);
- 優(yōu)先級確定:需求的必要性:功能是否必須,優(yōu)先級和重要程度怎樣,是否能被推進或被削減;
- 簡明性:簡明清晰:使用業(yè)務術(shù)語或縮略語,表達清晰明了;
- 可測試:可檢測和可跟蹤:可根據(jù)需求設(shè)計測試目標和測試進度,可跟蹤需求缺陷。
需求調(diào)研途徑:
- 訪談和調(diào)查表:輸出訪談記錄和調(diào)查報告
- 引導啟發(fā):在了解用戶組織架構(gòu)、業(yè)務流程、軟硬件環(huán)境、現(xiàn)有系統(tǒng)等的基礎(chǔ)上,結(jié)合demo原型系統(tǒng),引導用戶,挖掘用戶需求 輸出:分析報告、原型反饋
- 確認:在掌握細化流程、詳細數(shù)據(jù)的基礎(chǔ)上,確認簽字 輸出:需求分析文檔
需求分析的注意事項:
- 與客戶搞好關(guān)系;
- 統(tǒng)一的溝通渠道和溝通流程;
- 需求審批及變更審批
- 了解用戶分類和用戶操作習慣
軟件開發(fā)是由人來做的,最終決定質(zhì)量的因素還是人的因素,后期開發(fā)重點注意事項是團隊人員的選擇和項目管理
選擇開發(fā)團隊注意事項
- 選擇有開發(fā)經(jīng)驗的開發(fā)人員,主要是技術(shù)方面做過類似的模塊或功能,技術(shù)實力較好
- 選擇負責人的開發(fā)人員,認真,做事負責很重要
- 選擇團隊精神強的開發(fā)人員,軟件開發(fā)是團隊作業(yè),能夠很好的協(xié)作作業(yè)非常重要
- 制定合理的項目開發(fā)計劃,重點是合理性,如時間合理性,開發(fā)人員合理性
- 明確團隊工作任務,責任到人,團隊間每個人的工作任務必須明確化
- 做好核心業(yè)務,難點技術(shù)的公關(guān),抓好重點,對于難點技術(shù)技術(shù)負責人要提前驗證寫出demo,對于核心業(yè)務流程要集中開發(fā)
- 上一篇: 北京軟件開發(fā)公司有哪些,軟件技術(shù)水平怎么樣
- 下一篇: 軟件開發(fā)外包注意事項