軟件開發(fā)
軟件開發(fā)是指設(shè)計和構(gòu)建計算機程序以滿足用戶需求的過程。這個過程通常被稱為軟件開發(fā)生命周期(SDLC),它包括需求分析、設(shè)計、編程、測試和維護等多個階段。這些階段的目標(biāo)是創(chuàng)建一個滿足用戶需求的高質(zhì)量軟件產(chǎn)品。
軟件開發(fā)經(jīng)歷了不同的階段,包括編程階段、軟件設(shè)計階段和軟件工程階段。常見的軟件過程模型包括瀑布模型、原型模型、螺旋模型、組件復(fù)用模型和敏捷軟件開發(fā)過程模型,以滿足不同項目的需求。軟件開發(fā)環(huán)境可以根據(jù)解決的問題或開發(fā)環(huán)境的演變趨勢進行分類。軟件開發(fā)工具通常由三部分組成:工具本身、工具界面和工具用戶界面。常用的軟件開發(fā)語言包括Java、Python、C/C++、JavaScript等。
未來,云計算、低代碼和無代碼開發(fā)、人工智能、物聯(lián)網(wǎng)、DevOps、區(qū)塊鏈和遠程辦公等趨勢將進一步推動軟件開發(fā)的發(fā)展,并為用戶提供更友好的體驗和功能。
定義概述
軟件是用于操作計算機和執(zhí)行特定任務(wù)的一系列指令、數(shù)據(jù)或程序。軟件開發(fā)是設(shè)計、創(chuàng)建、測試和維護不同軟件應(yīng)用程序或系統(tǒng)的集體過程,包括從需求分析、設(shè)計、編程、測試到維護的所有階段。這些階段反映了系統(tǒng)開發(fā)生命周期(SDLC)的所有方面,包括滿足業(yè)務(wù)需求的設(shè)計、滿足指定設(shè)計的開發(fā)、將軟件部署到生產(chǎn)環(huán)境以及后續(xù)的支持和維護。
發(fā)展歷程
軟件開發(fā)的歷史可以追溯到1804年,當(dāng)時約瑟夫·瑪麗·雅卡爾在紙板上打孔,以引導(dǎo)織機編織圖案。
19世紀(jì)末,“計算機之父”查爾斯·巴貝奇發(fā)明了第一臺機械計算機,被稱為分析引擎,后來成為其他計算機設(shè)計和電子計算機的靈感來源。雖然這些機器還沒有制造出來,但這并不意味著不能為它們編寫“軟件”。
1843年,世界上第一個程序員阿達·洛芙萊斯為查爾斯·巴貝奇的分析引擎開發(fā)了一種計算伯努利數(shù)的算法,這被認為是第一個計算機程序。同時,她的工作對計算機科學(xué)的發(fā)展產(chǎn)生了重要影響。她不僅將機器視為執(zhí)行數(shù)學(xué)計算的工具,還認識到計算機可以處理不同類型的信息。她的思想開創(chuàng)了圖靈機的概念,奠定了計算機科學(xué)的基礎(chǔ)。
1889年,赫爾曼·何樂禮發(fā)明了霍爾瑞斯制表機,它通過編程對數(shù)據(jù)進行計數(shù)和制表?;魻柸鹚怪票砥鞯陌l(fā)明標(biāo)志著數(shù)據(jù)處理和自動化的重要進展,對軟件開發(fā)的演變產(chǎn)生了一定的影響。
1936年,艾倫·圖靈提出了圖靈機的概念,其關(guān)鍵思想是抽象計算過程,被認為是計算機科學(xué)的開創(chuàng)性理論之一,成為計算機科學(xué)中許多理論和算法的基礎(chǔ)。隨著計算機技術(shù)的發(fā)展,軟件開發(fā)經(jīng)歷了程序設(shè)計、軟件設(shè)計和軟件工程階段。編程階段出現(xiàn)在1946-1955年。1946年,美國物理學(xué)家和工程師約翰·莫奇利和約翰·p·??颂卦谫e夕法尼亞大學(xué)共同發(fā)明了第一臺通用計算機(ENIAC)。它是一個巨人,有18000個電子管,面積170平方米,重30噸,消耗約150千瓦的功率,每秒進行5000次運算。ENIAC是一個研究主機,使用電子管作為元件。它體積龐大,耗電量大,容易發(fā)熱,并且不能工作太長時間。在這個第一代計算機(電子管)階段,還沒有軟件的概念。程序設(shè)計主要圍繞硬件開發(fā),追求節(jié)省空間和編程技巧。規(guī)模很小,工具簡單,沒有明確的分工(開發(fā)人員和用戶),也沒有文檔(程序列表除外),主要用于科學(xué)計算。
1948年,一位名叫湯姆·基爾本的英國計算機科學(xué)家使用8個字的工作內(nèi)存和17個字的指令編寫了世界上第一個軟件。他和他的同事弗雷迪·威廉姆斯開發(fā)了世界上最早的計算機之一——曼徹斯特小型實驗機(SSEM),并運行基爾本的代碼進行數(shù)學(xué)計算。
1949年,John Mauchly提出了第一個高級編程語言Brief Code(后來稱為短代碼),并由William F. Schmidt實現(xiàn)。Brief Code是第一種函數(shù)式編程語言,它以易于理解的數(shù)學(xué)表達式呈現(xiàn),但每次運行程序時都必須將其轉(zhuǎn)換為機器代碼,這使得軟件開發(fā)過程更加緩慢。
1951年,美國海軍軍官格雷斯·霍珀為UNIVAC創(chuàng)建了第一個計算機語言編譯器A-0(算術(shù)語言版本0),它是COBOL的前身。
1952年,Alick Glennie開發(fā)了Autocode,這是第一種可以由編譯器直接轉(zhuǎn)換為機器代碼的編譯語言,也是描述一種曼徹斯特Mark 1自動編碼系統(tǒng)的術(shù)語。兩年后,R.A. Brooker開發(fā)了第二個版本的Autocode,稱為Mark 1 Autocode。
1954年,IBM的一個團隊開發(fā)了FORTRAN語言,這是至今仍在使用的最古老的高級編程語言。軟件設(shè)計階段出現(xiàn)在1956-1970年。這是第二代計算機(晶體管數(shù)字計算機)和第三代計算機(集成電路數(shù)字計算機),商用主機和商用微型計算機已逐漸出現(xiàn)。其特點是:硬件環(huán)境相對穩(wěn)定,有軟件作坊式的開發(fā)組織形式;產(chǎn)品軟件(可購買)被廣泛使用,從而建立了軟件的概念,出現(xiàn)了BIOS、操作系統(tǒng)和數(shù)據(jù)庫管理系統(tǒng)等系統(tǒng)軟件,并出現(xiàn)了瀑布模型。隨著計算機技術(shù)的發(fā)展和計算機應(yīng)用的日益普及,軟件系統(tǒng)的規(guī)模越來越大,從科學(xué)計算到商業(yè)應(yīng)用,高級編程語言層出不窮,應(yīng)用領(lǐng)域不斷擴大,開發(fā)人員和用戶分工明確,對軟件的需求急劇增加,逐漸形成了結(jié)構(gòu)化編程和結(jié)構(gòu)化分析與設(shè)計的軟件開發(fā)技術(shù),但軟件產(chǎn)品質(zhì)量不高,生產(chǎn)效率低,導(dǎo)致軟件危機的出現(xiàn)。即落后的軟件生產(chǎn)模式無法滿足快速增長的計算機軟件需求,導(dǎo)致軟件開發(fā)和維護過程中出現(xiàn)一系列嚴重問題。
1958年,一個科學(xué)委員會開發(fā)了ALGOL,一種用于研究和科學(xué)目的的編程語言。Java和許多其他高級語言在某種程度上是從這種語言演變而來的。
1959年,格蕾絲·霍珀和鮑勃·貝默開發(fā)了COBOL(通用商業(yè)語言),這是第一種可以在各種類型或品牌的計算機上運行的高級編程語言。它仍然廣泛應(yīng)用于卡處理、ATM機甚至電影中的視覺效果。同樣在1959年,麻省理工學(xué)院的約翰·麥卡錫為開發(fā)人工智能創(chuàng)建了第一版LISP語言,該語言一直沿用至今。
1964年5月1日,由John Kemeny和Thomas Kurtz開發(fā)的BASIC語言向公眾推出。許多商業(yè)應(yīng)用程序仍在使用BASIC語言。微軟的Visual BASIC(VB)在標(biāo)準(zhǔn)BASIC基礎(chǔ)上增加了面向?qū)ο蟮墓δ芎蛨D形用戶界面。軟件工程階段從1970年開始出現(xiàn)。這是第四代計算機(大規(guī)模集成電路機)及其后期階段。個人電腦已經(jīng)普及,圖形操作系統(tǒng)已經(jīng)建立。軟件危機迫使人們研究和改變軟件開發(fā)的技術(shù)手段和管理方法,形成了現(xiàn)代結(jié)構(gòu)化方法、面向?qū)ο缶幊毯蛙浖赜?,并開始使用增量進化的開發(fā)模型。從此,軟件生產(chǎn)進入了軟件工程時代。這一階段的特點是:硬件向巨型化、小型化、網(wǎng)絡(luò)化和智能化四個方向發(fā)展,數(shù)據(jù)庫技術(shù)成熟并得到廣泛應(yīng)用,出現(xiàn)了第三代和第四代編程語言;第一代軟件技術(shù)(結(jié)構(gòu)化程序設(shè)計)在數(shù)值計算領(lǐng)域取得了突出成就;第二代軟件技術(shù)(軟件測試技術(shù)、方法和原理)用于軟件生產(chǎn)過程;第三代軟件技術(shù)(處理需求定義技術(shù))用于軟件需求分析和描述。
1972年,丹尼斯·里奇在貝爾實驗室開發(fā)了C語言,該語言成為當(dāng)時最流行的編程語言之一,并對后來的許多編程語言產(chǎn)生了巨大影響。同年,Donald D. Chamberlin和Raymond F. Boyce開發(fā)了SQL(結(jié)構(gòu)化查詢語言),它是為數(shù)據(jù)庫的使用而設(shè)計的,SQL仍然是最流行的數(shù)據(jù)庫語言之一。從20世紀(jì)60年代末到70年代末,有許多流行的編程范例,如Simula、C和Prolog。上世紀(jì)七八十年代,隨著Apple II系統(tǒng)的發(fā)布,軟件開發(fā)開始發(fā)揮重要作用。與此同時,與蘋果Apple II系統(tǒng)競爭的產(chǎn)品VisiCalc問世,并首次將電子表格軟件帶到公眾面前。隨著人們對個人電腦領(lǐng)域越來越感興趣,許多公司,如行業(yè)巨頭IBM,被吸引進入該市場。然而,盡管它被稱為“個人電腦”,但這一時期開發(fā)的大多數(shù)軟件都與工作和商業(yè)社區(qū)密切相關(guān),其中最重要的應(yīng)用程序是Microsoft Word和Excel。
在20世紀(jì)80年代,另一個重要趨勢是使用模塊,即代碼的大規(guī)模組織單元。與此同時,面向?qū)ο蟮奶匦?,如封裝、繼承和多態(tài)也起源于這十年。1983年,比雅尼·斯特勞斯特魯普開發(fā)的C++引入了面向?qū)ο缶幊痰母拍睿谟螒蛞婧蚖eb開發(fā)中得到了廣泛應(yīng)用。同年,Objective-C語言發(fā)布并應(yīng)用于蘋果的操作系統(tǒng)、macOS和IOS。這一時期的其他重要編程語言包括Ada(1983年)、Common Lisp(CL)(1984年)、Eiffel(1984年)、Perl(1987年)和TCL腳本語言(1988年)。
開源程序的發(fā)布也成為改變軟件開發(fā)規(guī)則的重要力量,軟件開發(fā)在20世紀(jì)90年代開始流行,主要是由在線興趣驅(qū)動的。例如,Linux內(nèi)核的最早版本(后來發(fā)展成為同名操作系統(tǒng))于1991年在線發(fā)布。
同樣在1991年,Guido Van Rossum創(chuàng)建了一種非常用戶友好的編程語言Python,這是當(dāng)今最流行的語言之一。1995年,Brendan Eich僅用10天就創(chuàng)建了JavaScript,這是使用最廣泛的編程語言之一,也是萬維網(wǎng)的核心技術(shù)之一。同年,由詹姆斯·高斯林和太陽微系統(tǒng)公司的其他開發(fā)人員開發(fā)的Java語言向公眾推出。
20世紀(jì)90年代創(chuàng)建的其他著名編程語言包括Haskell(1991年)、Visual Basic(1991年)、Lua(1993年)、R(1993年)、Ruby(1995年)、Ada 95(1995年)、PHP(1995年)和Rebol。函數(shù)式編程、數(shù)據(jù)分析和Web開發(fā)也在此期間得到了發(fā)展。自1996年以來,計算機開始通過移動設(shè)備影響公眾,如PDA(Palm OS)和黑莓系列。
2001年,微軟開發(fā)了C#語言,它與C++、Java和Visual Basic非常相似,被廣泛用于微軟產(chǎn)品和桌面應(yīng)用程序的開發(fā)。2003年,Martin Odersky為Android開發(fā)創(chuàng)建了Scala語言。同年,谷歌開發(fā)了Go語言來解決大型軟件系統(tǒng)出現(xiàn)的問題。2007年,蘋果推出了iPhone,標(biāo)志著移動技術(shù)新時代的開始。2012年發(fā)布的TypeScript語言是JavaScript語言的語法超集,增加了靜態(tài)類型,它也是Angular框架的重要組成部分。2014年,蘋果開發(fā)了Swift語言來取代C#、C和C++。
在Rust世紀(jì)出現(xiàn)了許多其他重要的編程語言,例如action script(2000年)、D(2001年)、Scratch(2002年)、Groovy(2003年)、F #(2005年)、PowerShell(2006年)和clo jure(2007年)。
隨著互聯(lián)網(wǎng)技術(shù)的蓬勃發(fā)展,網(wǎng)絡(luò)操作系統(tǒng)和中間件平臺也促進了軟件開發(fā)技術(shù)的發(fā)展和成熟,敏捷開發(fā)方法逐漸流行起來。未來有望在互聯(lián)網(wǎng)平臺上進一步整合資源,形成高效可信的虛擬環(huán)境,更好地服務(wù)所有用戶。軟件復(fù)用和軟件構(gòu)件技術(shù)被認為是解決軟件危機的現(xiàn)實途徑和實現(xiàn)軟件工業(yè)化生產(chǎn)的必要手段。軟件工程將向開放計算方向發(fā)展,確定行業(yè)的基本框架,并引導(dǎo)行業(yè)的發(fā)展和技術(shù)融合。
生命周期
軟件項目的開發(fā)需要先計劃,后實施。在軟件開發(fā)和維護的漫長生命周期中,需要完成許多不同性質(zhì)的任務(wù),這意味著要將軟件生命周期分為幾個階段,并據(jù)此制定可行的計劃,然后嚴格按照計劃管理軟件開發(fā)和維護。
軟件開發(fā)生命周期(SDLC)提供了一個國際標(biāo)準(zhǔn),軟件公司可以使用該標(biāo)準(zhǔn)來構(gòu)建和改進他們的計算機程序。它可以分為以下幾個階段:可行性研究、需求分析、總體設(shè)計、詳細設(shè)計、系統(tǒng)測試、系統(tǒng)部署和系統(tǒng)維護。
可行性研究:在可行性研究階段,需要進行廣泛的市場調(diào)查,以確定產(chǎn)品的可行性并同時規(guī)劃項目。這一階段涉及資源分配、產(chǎn)能規(guī)劃、項目調(diào)度、成本估算和供應(yīng)。理想情況下,項目經(jīng)理和開發(fā)人員應(yīng)該與操作和安全團隊密切合作,以確保所有相關(guān)方的意見都得到充分考慮。這一階段的主要成果包括詳細的項目計劃、時間表、準(zhǔn)確的成本估算和必要的采購要求。
需求分析:需求分析是軟件開發(fā)生命周期的第二階段。在此階段,利益相關(guān)者就提議產(chǎn)品的技術(shù)和用戶要求及規(guī)格達成一致,以實現(xiàn)其目標(biāo)。此階段的首要任務(wù)是收集需求,以了解和歸檔用戶和其他利益相關(guān)者的需求。通過需求分析,提供每個組件測試參數(shù)的詳細概述、范圍、開發(fā)人員和任務(wù),以確保高質(zhì)量的產(chǎn)品開發(fā)。同時,這個階段涉及開發(fā)人員、用戶、測試人員、項目經(jīng)理和質(zhì)量保證人員之間的密切合作。程序員也會在這個階段選擇合適的軟件開發(fā)方法,如瀑布模型或V模型。團隊將此階段的結(jié)果記錄在軟件需求規(guī)范文檔中,該文檔可作為團隊在項目實施過程中的參考。
總體設(shè)計:總體設(shè)計是軟件開發(fā)生命周期的第三階段。在這個階段,架構(gòu)師和開發(fā)人員不僅要制定所需的高級技術(shù)規(guī)范以創(chuàng)建符合要求的軟件,還要選擇或構(gòu)建軟件的底層架構(gòu),為整個系統(tǒng)提供可靠的基礎(chǔ)。這個階段可能還包括一些快速原型制作。利益相關(guān)者將討論風(fēng)險級別、團隊組成、適用技術(shù)、時間、預(yù)算、項目限制、方法和架構(gòu)設(shè)計等因素。設(shè)計規(guī)范文檔(DSD)詳細說明了產(chǎn)品的架構(gòu)設(shè)計、組件、通信、前端表示和用戶流。這一步為開發(fā)人員和測試人員提供了一個模板,并減少了成品出現(xiàn)缺陷和延遲的可能性。
細節(jié)設(shè)計:詳細設(shè)計階段是軟件開發(fā)過程中的關(guān)鍵步驟。在此階段,開發(fā)人員開始實際編寫代碼以開發(fā)軟件,并根據(jù)公司的程序和指南,基于前一階段商定的產(chǎn)品規(guī)格和要求進行編碼。前端開發(fā)人員構(gòu)建接口,后端開發(fā)人員創(chuàng)建與數(shù)據(jù)庫相關(guān)的數(shù)據(jù)。同時,詳細設(shè)計階段還涉及相關(guān)的解決方案設(shè)計,并使用流程模型和故事板詳細定義解決方案的思想。開發(fā)人員使用建模工具構(gòu)建模型,用于早期驗證、原型制作和設(shè)計模擬。為了保證軟件的質(zhì)量,開發(fā)人員用相應(yīng)的編程語言編寫設(shè)計代碼,并參與同行和團隊的評估。此外,在此階段應(yīng)定期聯(lián)系業(yè)務(wù)利益相關(guān)者,以確保他們的期望得到滿足。最后,這個階段的輸出是可測試的功能軟件。
系統(tǒng)測試:系統(tǒng)測試階段是軟件開發(fā)過程中保證軟件質(zhì)量的關(guān)鍵環(huán)節(jié)。在此階段,測試人員通過單元測試(功能測試)、集成測試、性能測試和安全測試來驗證產(chǎn)品的功能,并確保其按照需求分析文檔的要求進行。一些團隊選擇自動化測試執(zhí)行過程,并使用持續(xù)集成工具(如Appveyor或Travis CI)更有效地發(fā)現(xiàn)錯誤。測試人員負責(zé)通知開發(fā)人員代碼中的缺陷。在開發(fā)人員確認并修復(fù)這些缺陷后,測試人員將重復(fù)測試過程,直到他們確保軟件沒有問題并且可以按要求運行。此外,系統(tǒng)測試階段還體現(xiàn)在軟件設(shè)計和編碼過程中,包括預(yù)先計劃的場景測試和性能測試,以模擬應(yīng)用程序的實際負載,從而確保軟件在各種條件下的穩(wěn)定性和可靠性。
系統(tǒng)部署:系統(tǒng)部署階段的目標(biāo)是將軟件部署到生產(chǎn)環(huán)境中以供實際使用。在高度成熟的企業(yè)中,這一階段通常是高度自動化的,軟件一旦準(zhǔn)備好就將部署到生產(chǎn)環(huán)境中。對于成熟度較低的企業(yè)或一些高度標(biāo)準(zhǔn)化的行業(yè),部署過程可能涉及一些人工審批。在大中型企業(yè)中,為了簡化部署過程,通常使用應(yīng)用程序發(fā)布自動化(ARA)工具,該工具可以與持續(xù)集成工具集成,使將應(yīng)用程序部署到生產(chǎn)環(huán)境的過程更加自動化。此外,系統(tǒng)部署階段還負責(zé)響應(yīng)和解決用戶在使用過程中遇到的問題,并在必要時遷移數(shù)據(jù)。
系統(tǒng)維護:軟件開發(fā)周期不會在系統(tǒng)維護的這個階段結(jié)束,必須不斷監(jiān)控軟件以確保其正常運行。作為軟件開發(fā)過程中的關(guān)鍵環(huán)節(jié),系統(tǒng)維護階段致力于確保軟件的正常運行和持續(xù)改進。在生產(chǎn)環(huán)境中發(fā)現(xiàn)的問題和缺陷必須及時報告和響應(yīng),這通常會將工作重新引入開發(fā)過程。對于bug修復(fù),可能不需要經(jīng)歷整個開發(fā)過程,但至少需要一個簡化的過程來確保修復(fù)不會引入其他問題(回歸問題),以避免問題擴大。
在系統(tǒng)維護階段,團隊還需要管理和評估整個項目,以保持應(yīng)用程序生命周期的質(zhì)量和交付。為此,使用能力成熟度模型(CMM)等評估模型來評估開發(fā)過程,以確保過程的科學(xué)性和效率。同時,構(gòu)建不同版本的軟件也是現(xiàn)階段的任務(wù)之一。通過確定質(zhì)量保證優(yōu)先級和發(fā)布標(biāo)準(zhǔn),團隊可以解決和跟蹤系統(tǒng)缺陷,并確保軟件在迭代過程中不斷優(yōu)化和改進。