探討解決問題的方案,并對(duì)可供使用的資源(如計(jì)算機(jī)硬件、系統(tǒng)軟件、人力等)成本,可取得的效益和開發(fā)進(jìn)度作出估計(jì),制訂完成開發(fā)任務(wù)的實(shí)施計(jì)劃。軟件開發(fā)2分析軟件需求分析就是對(duì)開發(fā)什么樣的軟件的一個(gè)系統(tǒng)的分析與設(shè)想。它是一個(gè)對(duì)用戶的需求進(jìn)行去粗取精、去偽存真、正確理解,然后把它用軟件工程開發(fā)語言(形式功能規(guī)約,即需求規(guī)格說明書)表達(dá)出來的過程。本階段的基本任務(wù)是和用戶一起確定要解決的問題,建立軟件的邏輯模型,編寫需求規(guī)格說明書文檔并**終得到用戶的認(rèn)可。需求分析的主要方法有結(jié)構(gòu)化分析方法、數(shù)據(jù)流程圖和數(shù)據(jù)字典等方法。本階段的工作是根據(jù)需求說明書的要求,設(shè)計(jì)建立相應(yīng)的軟件系統(tǒng)的體系結(jié)構(gòu),并將整個(gè)系統(tǒng)分解成若干個(gè)子系統(tǒng)或模塊,定義子系統(tǒng)或模塊間的接口關(guān)系,對(duì)各子系統(tǒng)進(jìn)行具體設(shè)計(jì)定義,編寫軟件概要設(shè)計(jì)和詳細(xì)設(shè)計(jì)說明書,數(shù)據(jù)庫或數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)說明書,組裝測(cè)試計(jì)劃。在任何軟件或系統(tǒng)開發(fā)的初始階段必須先完全掌握用戶需求,以期能將緊隨的系統(tǒng)開發(fā)過程中哪些功能應(yīng)該落實(shí)、采取何種規(guī)格以及設(shè)定哪些限制優(yōu)先加以定位。系統(tǒng)工程師**終將據(jù)此完成設(shè)計(jì)方案,在此基礎(chǔ)上對(duì)隨后的程序開發(fā)、系統(tǒng)功能和性能的描述及限制作出定義。與這些程序相關(guān)的文件一般也被認(rèn)為是軟件的一部分。 軟件設(shè)計(jì)思路和方法的一般過程。盤龍區(qū)正規(guī)軟件開發(fā)
錯(cuò)誤4:忽視監(jiān)督項(xiàng)目的進(jìn)度到目前為止,軟件產(chǎn)業(yè)還沒有一個(gè)標(biāo)準(zhǔn)的項(xiàng)目進(jìn)度的檢查標(biāo)準(zhǔn)。一個(gè)比較清晰的尺度是用已經(jīng)實(shí)現(xiàn)的軟件功能反映項(xiàng)目的進(jìn)度。但這種方法是否就是**科學(xué)的衡量標(biāo)準(zhǔn),現(xiàn)在還不能定論,畢竟在一個(gè)軟件項(xiàng)目中軟件功能只是一個(gè)主要而非全部的任務(wù)。因此一個(gè)項(xiàng)目經(jīng)理在監(jiān)控項(xiàng)目執(zhí)行時(shí)不應(yīng)該只關(guān)注實(shí)現(xiàn)的軟件功能,還要關(guān)心文檔,測(cè)試,技術(shù)支持這些因素。在實(shí)際工作中我們經(jīng)常聽到經(jīng)理或程序員說這樣的話:"項(xiàng)目已經(jīng)完成了90%",這種結(jié)論帶有明顯的主觀性,一個(gè)***的項(xiàng)目經(jīng)理不應(yīng)該被手下的判斷所迷惑,而應(yīng)該按照一個(gè)比較客觀的標(biāo)準(zhǔn)去深入檢查。錯(cuò)誤5:忽視設(shè)計(jì)復(fù)查和代碼復(fù)查很多程序員習(xí)慣于這樣一種工作方式:只做不想。他們更關(guān)心每天可以寫多少行代碼,完成幾個(gè)模塊。在這種態(tài)度下,他們都很不愿意復(fù)查自己的工作,而習(xí)慣于在軟件測(cè)試階段把隱藏的錯(cuò)誤改正過來。但設(shè)計(jì)復(fù)查和代碼復(fù)查在大型的軟件項(xiàng)目中已經(jīng)有30年的應(yīng)用歷史,而且已經(jīng)被證明在設(shè)計(jì)和代碼編寫階段的復(fù)查比軟件測(cè)試更能有效的消除錯(cuò)誤,一些經(jīng)驗(yàn)數(shù)據(jù)表明,在設(shè)計(jì)和代碼復(fù)查時(shí)發(fā)現(xiàn)的錯(cuò)誤是在同等工作量下軟件測(cè)試發(fā)現(xiàn)的錯(cuò)誤的兩倍。結(jié)論:軟件開發(fā)是一個(gè)帶有一定風(fēng)險(xiǎn)的工作,為了把風(fēng)險(xiǎn)降到**低。嵩明信息化軟件開發(fā)咨詢報(bào)價(jià)可取得的效益和開發(fā)進(jìn)度作出估計(jì),制訂完成開發(fā)任務(wù)的實(shí)施計(jì)劃。
M.A.Jackson提出了一類至今仍***使用的軟件開發(fā)方法。這一方法從目標(biāo)系統(tǒng)的輸入、輸出數(shù)據(jù)結(jié)構(gòu)入手,導(dǎo)出程序框架結(jié)構(gòu),再補(bǔ)充其它細(xì)節(jié),就可得到完整的程序結(jié)構(gòu)圖。這一方法對(duì)輸入、輸出數(shù)據(jù)結(jié)構(gòu)明確的中小型系統(tǒng)特別有效,如商業(yè)應(yīng)用中的文件表格處理。該方法也可與其它方法結(jié)合,用于模塊的詳細(xì)設(shè)計(jì)。Jackson方法有時(shí)也稱為面向數(shù)據(jù)結(jié)構(gòu)的軟件設(shè)計(jì)方法。Warnier方法1974年,J.D.Warnier提出的軟件開發(fā)方法與Jackson方法類似。差別有三點(diǎn):一是它們使用的圖形工具不同,分別使用Warnier圖和Jackson圖;另一個(gè)差別是使用的偽碼不同;**主要的差別是在構(gòu)造程序框架時(shí),Warnier方法*考慮輸入數(shù)據(jù)結(jié)構(gòu),而Jackson方法不*考慮輸入數(shù)據(jù)結(jié)構(gòu),而且還考慮輸出數(shù)據(jù)結(jié)構(gòu)。四、問題分析法PAM問題分析法。PAM(ProblemAnalysisMethod)是80年代末由日立公司提出的一種軟件開發(fā)方法。PAM方法希望能兼顧Yourdon方法、Jackson方法和自底向上的軟件開發(fā)方法的優(yōu)點(diǎn),而避免它們的缺陷。它的基本思想是:考慮到輸入、輸出數(shù)據(jù)結(jié)構(gòu),指導(dǎo)系統(tǒng)的分解,在系統(tǒng)分析指導(dǎo)下逐步綜合。這一方法的具體步驟是:從輸入、輸出數(shù)據(jù)結(jié)構(gòu)導(dǎo)出基本處理框;分析這些處理框之間的先后關(guān)系。
現(xiàn)在國(guó)外市場(chǎng)上有大約50種商業(yè)軟件費(fèi)用估計(jì)工具包和大約100種商業(yè)項(xiàng)目計(jì)劃工具包,使用他們作精確的估計(jì)比手工的估計(jì)更可能獲得成功。常用的軟件費(fèi)用估計(jì)工具軟件有Checkpoint,Colomo,Estimacs,Price_s,Slim。常用的項(xiàng)目管理軟件有MSProject,Primavera,ProjectManager*sWorkbench,Timeline。把這二種工具軟件聯(lián)合使用可以互為補(bǔ)充,幫助經(jīng)理駁回客戶和程序員的無理要求并且能精確的控制項(xiàng)目的執(zhí)行。錯(cuò)誤3:忽視用戶的需求的變動(dòng)盡管**初的用戶需求在簽定開發(fā)合同時(shí)已經(jīng)包含在需求說明書中,但在整個(gè)開發(fā)周期中期望用戶的需求一直保持不變是不大可能的,因?yàn)橛脩魧?duì)于如何應(yīng)用計(jì)算機(jī)軟件并沒有一個(gè)成熟的經(jīng)驗(yàn)。在項(xiàng)目進(jìn)行中用戶的需求會(huì)不斷的增長(zhǎng),一般情況下用戶的需求以每月1%的速率增加,如果一個(gè)項(xiàng)目在12個(gè)月內(nèi)完成,**終將有超過10%的改動(dòng),如果項(xiàng)目要持續(xù)36個(gè)月,**后將增加1/3的功能。每月1%也只是一個(gè)經(jīng)驗(yàn)數(shù)據(jù),一個(gè)缺乏計(jì)算機(jī)應(yīng)用經(jīng)驗(yàn)的用戶會(huì)更頻繁的改變和增加他的要求。因此在作項(xiàng)目的費(fèi)用和時(shí)間估計(jì)時(shí)一定要考慮用戶需求的變化。一種比較明智的方法是在簽定開發(fā)合同時(shí)把用戶需求的改動(dòng)和經(jīng)濟(jì)利益掛鉤,如果用戶增加或改動(dòng)了需求,那么軟件的交付日期可以推遲,費(fèi)用也應(yīng)增加。軟件開發(fā)是一項(xiàng)包括需求捕捉、需求分析、設(shè)計(jì)、實(shí)現(xiàn)和測(cè)試的系統(tǒng)工程。
④保密條款的**性:雙方可以約定,不論合同是否變更、解除或終止,合同保密條款不受其限制而繼續(xù)有效,各方均應(yīng)繼續(xù)承擔(dān)約定的保密義務(wù)。11、合同雙方的權(quán)利義務(wù)是否可以轉(zhuǎn)讓。12、簽約細(xì)節(jié)①合同中應(yīng)當(dāng)說明雙方當(dāng)事人信息。如當(dāng)事人名稱,住所,法定**人或主要負(fù)責(zé)人,開戶金融機(jī)構(gòu),帳號(hào),電話,郵政編碼,簽訂合同日期。簽訂合同地點(diǎn)等。②雙方均應(yīng)簽署清楚無誤的簽名,當(dāng)事方是單位的還應(yīng)加蓋公章。③簽訂時(shí)間:雙方應(yīng)在合同尾部標(biāo)明清楚無誤的簽約時(shí)間。④合同用語要力求達(dá)到條款明確、具體、措辭確切,防止“基本”、“盡可能”、“如有可能”“應(yīng)該”“**新”等不確切的條款和字眼在合同中出現(xiàn)。13、不可抗力①一方發(fā)生不可抗力時(shí)應(yīng)當(dāng)按照約定及時(shí)向?qū)Ψ礁嬷?、證明,并應(yīng)及時(shí)采取措施防止損失擴(kuò)大。②雙方當(dāng)事人應(yīng)當(dāng)明確約定不可抗力的范圍、遭遇不可抗力后的通知辦法和證明方法、雙方可否因不可抗力解除合同、可否因不可抗力造成的履行問題要求賠償、在何種情況下解除合同等。③一方發(fā)生不可抗力后應(yīng)依約及時(shí)向?qū)Ψ礁嬷⒆C明時(shí)應(yīng)保存證據(jù)。14、履行過程中雙方都應(yīng)注意相對(duì)方主體變更情況,若有變更解散情形的,應(yīng)注意哪個(gè)法人或組織繼受其權(quán)利義務(wù)。對(duì)所要解決的問題進(jìn)行總體定義,包括了解用戶的要求及現(xiàn)實(shí)環(huán)境。專業(yè)性軟件開發(fā)零售價(jià)格
軟件一般是用某種程序設(shè)計(jì)語言來實(shí)現(xiàn)的。通常采用軟件開發(fā)工具可以進(jìn)行開發(fā)。盤龍區(qū)正規(guī)軟件開發(fā)
按先后關(guān)系逐步綜合處理框,直到畫出整個(gè)系統(tǒng)的PAD圖。從上述步驟中可以看出,這一方法本質(zhì)上是綜合的自底向上的方法,但在逐步綜合之前已進(jìn)行了有目的的分解,這個(gè)目的就是充分考慮系統(tǒng)的輸入、輸出數(shù)據(jù)結(jié)構(gòu)。PAM方法的另一個(gè)優(yōu)點(diǎn)是使用PAD圖。這是一種二維樹形結(jié)構(gòu)圖,是到目前為止**好的詳細(xì)設(shè)計(jì)表示方法之一,遠(yuǎn)遠(yuǎn)優(yōu)于NS圖和PDL語言。這一方法在日本較為流行,軟件開發(fā)的成功率也很高。由于在輸入、輸出數(shù)據(jù)結(jié)構(gòu)與整個(gè)系統(tǒng)之間同樣存在著鴻溝,這一方法仍只適用于中小型問題。五、面向?qū)ο蟮能浖_發(fā)方法面向?qū)ο蠹夹g(shù)是軟件技術(shù)的一次**,在軟件開發(fā)史上具有里程碑的意義。隨著OOP(面向?qū)ο缶幊蹋┫騉OD(面向?qū)ο笤O(shè)計(jì))和OOA(面向?qū)ο蠓治觯┑陌l(fā)展,**終形成面向?qū)ο蟮能浖_發(fā)方法OMT(LbjectModellingTechnique)。這是一種自底向上和自頂向下相結(jié)合的方法,而且它以對(duì)象建模為基礎(chǔ),從而不*考慮了輸入、輸出數(shù)據(jù)結(jié)構(gòu),實(shí)際上也包含了所有對(duì)象的數(shù)據(jù)結(jié)構(gòu)。所以O(shè)MT徹底實(shí)現(xiàn)了PAM沒有完全實(shí)現(xiàn)的目標(biāo)。不*如此,OO技術(shù)在需求分析、可維護(hù)性和可靠性這三個(gè)軟件開發(fā)的關(guān)鍵環(huán)節(jié)和質(zhì)量指標(biāo)上有了實(shí)質(zhì)性的突破,徹底地解決了在這些方面存在的嚴(yán)重問題。盤龍區(qū)正規(guī)軟件開發(fā)
昆明酷通科技有限公司致力于商務(wù)服務(wù),是一家生產(chǎn)型的公司。酷通供應(yīng)致力于為客戶提供良好的軟件開發(fā),一切以用戶需求為中心,深受廣大客戶的歡迎。公司注重以質(zhì)量為中心,以服務(wù)為理念,秉持誠(chéng)信為本的理念,打造商務(wù)服務(wù)良好品牌??嵬ü?yīng)立足于全國(guó)市場(chǎng),依托強(qiáng)大的研發(fā)實(shí)力,融合前沿的技術(shù)理念,飛快響應(yīng)客戶的變化需求。