1. 程式人生 > >軟體工程與軟體危機

軟體工程與軟體危機

軟體在開發和維護的過程中,會遇到很多問題,軟體工程作為一門學科,是為了解決軟體危機的,那麼什麼是軟體危機?

一、軟體危機

軟體危機泛指在計算機軟體的開發和維護過程中所遇到的一系列嚴重問題。

軟體危機主要表現:

1 軟體開發進度難以預測
拖延工期幾個月甚至幾年的現象並不罕見,這種現象降低了軟體開發組織的信譽。
2 軟體開發成本難以控制
投資一再追加,令人難於置信。往往是實際成本比預算成本高出一個數量級。
而為了趕進度和節約成本所採取的一些權宜之計又往往損害了軟體產品的質量,從而不可避免地會引起使用者的不滿。
3 使用者對產品功能難以滿足
開發人員和使用者之間很難溝通、矛盾很難統一。往往是軟體開發人員不能真正瞭解使用者的需求,而使用者又不瞭解計算機求解問題的模式和能力,雙方無法用共同熟悉的語言進行交流和描述。
在雙方互不充分了解的情況下,就倉促上陣設計系統、匆忙著手編寫程式,這種"閉門造車"的開發方式必然導致最終的產品不符合使用者的實際需要。
4 軟體產品質量無法保證
系統中的錯誤難以消除。軟體是邏輯產品,質量問題很難以統一的標準度量,因而造成質量控制困難。
軟體產品並不是沒有錯誤,而是盲目檢測很難發現錯誤,而隱藏下來的錯誤往往是造成重大事故的隱患。
5 軟體產品難以維護
軟體產品本質上是開發人員的程式碼化的邏輯思維活動,他人難以替代。除非是開發者本人,否則很難及時檢測、排除系統故障。
為使系統適應新的硬體環境,或根據使用者的需要在原系統中增加一些新的功能,又有可能增加系統中的錯誤。
6 軟體缺少適當的文件資料
文件資料是軟體必不可少的重要組成部分。實際上,軟體的文件資料是開發組織和使用者的之間權利和義務的合同書,是系統管理者、總體設計者向開發人員下達的任務書,是系統維護人員的技術指導手冊,是使用者的操作說明書。
缺乏必要的文件資料或者文件資料不合格,將給軟體開發和維護帶來許多嚴重的困難和問題。

 

軟體危機原因分析:

1 使用者需求不明確 在軟體開發過程中,使用者需求不明確問題主要體現在四個方面: 在軟體開發出來之前,使用者自己也不清楚軟體開發的具體需求; 使用者對軟體開發需求的描述不精確,可能有遺漏、有二義性、甚至有錯誤; 在軟體開發過程中,使用者還提出修改軟體開發功能、介面、支撐環境等方面的要求; 軟體開發人員對使用者需求的理解與使用者本來願望有差異。 2 缺乏正確的理論指導 缺乏有力的方法學和工具方面的支援。由於軟體開發不同於大多數其他工業產品,其開發過程是複雜的邏輯思維過程,其產品極大程度地依賴於開發人員高度的智力投入。由於過分地依靠程式設計人員在軟體開發過程中的技巧和創造性,加劇軟體開發產品的個性化,也是發生軟體開發危機的一個重要原因。 3 軟體開發規模越來越大 隨著軟體開發應用範圍的增廣,軟體開發規模愈來愈大。大型軟體開發專案需要組織一定的人力共同完成,而多數管理人員缺乏開發大型軟體開發系統的經驗,而多數軟體開發人員又缺乏管理方面的經驗。各類人員的資訊交流不及時、不準確、有時還會產生誤解。軟體開發專案開發人員不能有效地、獨立自主地處理大型軟體開發的全部關係和各個分支,因此容易產生疏漏和錯誤。 4 軟體開發複雜度越來越高 軟體開發不僅僅是在規模上快速地發展擴大,而且其複雜性也急劇地增加。軟體開發產品的特殊性和人類智力的侷限性,導致人們無力處理“複雜問題”。所謂“複雜問題”的概念是相對的,一旦人們採用先進的組織形式、開發方法和工具提高了軟體開發效率和能力,新的、更大的、更復雜的問題又擺在人們的面前。  

二、軟體工程

軟體工程是軟體危機的解決途徑,軟體工程誕生於60年代末期,它作為一個新興的工程學科,主要研究軟體生產的客觀規律性,建立與系統化軟體生產有關的概念、原則、方法、技術和工具,指導和支援軟體系統的生產活動,以期達到降低軟體生產成本 、改進軟體產品質量、提高軟體生產率水平的目標。軟體工程學從硬體工程和其他人類工程中吸收了許多成功的經驗,明確提出了軟體生命週期的模型,發展了許多軟體開發與維護階段適用的技術和方法,並應用於軟體工程實踐,取得良好的效果。 在軟體開發過程中人們開始研製和使用軟體工具,用以輔助進行軟體專案管理與技術生產,人們還將軟體生命週期各階段使用的軟體工具有機地集合成為一個整體,形成能夠連續支援軟體開發與維護全過程的整合化軟體支援環境,以期從管理和技術兩方面解決軟體危機問題。 此外,人工智慧與軟體工程的結合成為80年代末期活躍的研究領域。基於程式變換、自動生成和可重用軟體等軟體新技術研究也已取得一定的進展,把程式設計自動化的程序向前推進一步。在軟體工程理論的指導下,發達國家已經建立起較為完備的軟體工業化生產體系,形成了強大的軟體生產能力 。軟體標準化與可重用性得到了工業界的高度重視,在避免重用勞動,緩解軟體危機方面起到了重要作用。  

三、軟體需求的定義

 

&n