軟件開(kāi)發(fā)_第1頁(yè)
已閱讀1頁(yè),還剩50頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、軟件工程基礎(chǔ),軟件工程概述劉 馳,2,講授內(nèi)容,軟件工程的基本概念基于計(jì)算機(jī)的系統(tǒng)工程軟件過(guò)程,3,1. 什么是軟件?,Software=program+data+documentCustom softwareGeneric software, Shrink-wrapped softwareEmbedded softwareSafety-critical softwareCOTS(Commercial Off-th

2、e-Shelf)I will create a software to update the database.(a piece of software, or a software system)可以按功能、規(guī)模、工作方式、可靠性高低等進(jìn)行劃分,4,2. 什么是軟件工程?,1968年秋季,NATO(北約)的科技委員會(huì)召集了近50名一流的編程人員、計(jì)算機(jī)科學(xué)家和工業(yè)界巨頭,討論和制定擺脫“軟件危機(jī)”的對(duì)策。Fritz Bauer

3、在會(huì)議上首次提出“軟件工程”概念。The establishment and use of sound engineering principles in order to obtain economically software that is reliable and works efficiently on real machines.” --- Fritz Bauer, 1968,5,IEEE:軟件工程是(1)將系

4、統(tǒng)化的、規(guī)范的、可度量的方法應(yīng)用于軟件的開(kāi)發(fā)、運(yùn)行和維護(hù)的過(guò)程,即將工程化思想應(yīng)用于軟件開(kāi)發(fā)過(guò)程中(2)上述方法的研究。軟件工程的目標(biāo): 低成本, 高質(zhì)量, 按時(shí)交付,6,軟件工程的本質(zhì)特性,關(guān)注大型程序的構(gòu)造如何控制復(fù)雜性軟件需求不斷變化旨在提高軟件開(kāi)發(fā)的效率團(tuán)隊(duì)合作是軟件工程順利實(shí)施的關(guān)鍵軟件必須有效支持它的用戶(hù)由一種文化背景的人替另一種文化背景的人創(chuàng)造產(chǎn)品(設(shè)計(jì)者、使用者),7,3. SW and CS,計(jì)算機(jī)科學(xué)

5、研究的是構(gòu)成計(jì)算機(jī)和軟件系統(tǒng)基礎(chǔ)的有關(guān)理論和方法,而軟件工程則研究軟件制作中的實(shí)際問(wèn)題。理論上,所有軟件工程都應(yīng)該以計(jì)算機(jī)科學(xué)理論作為堅(jiān)實(shí)的基礎(chǔ),但對(duì)付實(shí)際的、復(fù)雜的問(wèn)題時(shí)需要用軟件工程的方法來(lái)解決。,8,4. SW and Systems Engineering,系統(tǒng)工程的產(chǎn)生比軟件工程早?;谟?jì)算機(jī)的系統(tǒng)工程,研究由軟件起主導(dǎo)作用的、有關(guān)負(fù)責(zé)系統(tǒng)的開(kāi)發(fā)和進(jìn)化的方方面面,包括硬件開(kāi)發(fā)、系統(tǒng)決策、過(guò)程設(shè)計(jì)、系統(tǒng)實(shí)施和軟件過(guò)程等。,

6、9,5. 什么是軟件過(guò)程?,軟件過(guò)程是指開(kāi)發(fā)軟件產(chǎn)品的一組活動(dòng)及其結(jié)果。所有的軟件過(guò)程都包含4項(xiàng)基本的活動(dòng):軟件描述、軟件開(kāi)發(fā)、軟件有效性驗(yàn)證和軟件進(jìn)化。不同的軟件過(guò)程以不同的方式組織這4項(xiàng)活動(dòng),活動(dòng)的結(jié)果會(huì)影響活動(dòng)的進(jìn)度。不同的機(jī)構(gòu)可能用不同的過(guò)程來(lái)制作同一類(lèi)產(chǎn)品。,10,為什么要定義軟件過(guò)程?,一個(gè)過(guò)程定義了為達(dá)到確定的目標(biāo),需要什么人在什么時(shí)間以何種方式做何種工作(Goal,Who,When,How,What)對(duì)于 Cus

7、tomer, User, Developer, Manager,一個(gè)廣泛適用的過(guò)程使得所有涉眾更好地理解自己所扮演的角色、更清楚地知道自己及他人在什么時(shí)間做什么。促使過(guò)程的有機(jī)結(jié)合和改善,以獲得“最好過(guò)程”可以使公司內(nèi)部的培訓(xùn)標(biāo)準(zhǔn)化。由于過(guò)程的可重復(fù)性,利于開(kāi)發(fā)進(jìn)度的安排,利于成本估算。,11,6. 什么是軟件過(guò)程模型?,模型與建模軟件過(guò)程模型是從一特定的角度對(duì)軟件過(guò)程的本質(zhì)描述。軟件過(guò)程模型包括構(gòu)成軟件過(guò)程的各種活動(dòng)、軟件產(chǎn)

8、品以及所有涉眾(stakeholder),12,從不同的角度對(duì)軟件過(guò)程的描述,就得到不同的過(guò)程模型種類(lèi)。如:工作流模型:描述軟件過(guò)程中各種活動(dòng)的序列及其輸入、輸出和相互依賴(lài)型。其中的活動(dòng)皆為人的活動(dòng)。數(shù)據(jù)流或活動(dòng)模型:把軟件過(guò)程描述成一組活動(dòng),其中每個(gè)活動(dòng)都完成一定的數(shù)據(jù)轉(zhuǎn)換。該模型中的活動(dòng)層次低于工作流模型。角色/動(dòng)作模型:描述參與軟件過(guò)程的不同角色及其所負(fù)責(zé)的活動(dòng)。,13,通用模型或范型(Paradigm, Methodolo

9、gy),Waterfall ModelWaterfall Model with Maintenance CircleWaterfall Model with PrototypingSpiral Model(瀑布模型+原型模型)V ModelPhased Development ModelIncremental and Iterative ModelRUP,14,7. 軟件工程的成本及成本分布,軟件成本分布取決于所采用的軟件

10、過(guò)程和所開(kāi)發(fā)的軟件類(lèi)型。一般的成本分布:描述:設(shè)計(jì):開(kāi)發(fā):集成與測(cè)試(15:25:20:40)需求極高的軟件系統(tǒng)的集成與測(cè)試成本50%軟件進(jìn)化的成本軟件維護(hù)的成本基于Web的電子商務(wù)系統(tǒng)的成本模型,15,8. 軟件工程方法 (Method),結(jié)構(gòu)化分析方法(Structured Method, DeMarco,1978, Yourdon E.和Constantine L. 等)JSD方法(Jackson System

11、Development,1983)OO方法(Object-Oriented Method, Booch, 1994;Rumbaugh等, 1991)? 設(shè)計(jì)模式,16,Tendency for Change when Using OO Paradigm (Jacobson et al. 1995),17,UML (Unified Modeling Language),1994,OO思想已經(jīng)貫穿整個(gè)軟件生存期,具有影響的OOA&a

12、mp;D方法達(dá)50余種。UML是一種對(duì)軟件密集型系統(tǒng)進(jìn)行可視化、詳述、構(gòu)造和文檔化的建模語(yǔ)言,主要用于分析和設(shè)計(jì)階段的系統(tǒng)建模。,18,UML 2.0,1994Booch方法Rumbaugh OMT Coad/YourdonFire Smith 方法 Jacobson OOSE……,1995.10發(fā)布Unified Method 0.8,,,1996.6發(fā)布UML 0.9不包含過(guò)程指導(dǎo),,,Rational聯(lián)合12家公

13、司成立UML組織,形成UML 1.0,1997.1提交給OMG,,,1997.11.4, OMG采納UML 1.1,,2002發(fā)布UML 2.0,19,10. 優(yōu)良軟件的屬性,功能屬性 (Functional)非功能屬性 (Non-Functional),20,11. 軟件工程所面臨的主要問(wèn)題,遺留系統(tǒng)的挑戰(zhàn) (Legacy systems)交付上的挑戰(zhàn)復(fù)雜性與大量的細(xì)節(jié)(火星探測(cè)器的失?。┘夹g(shù)的不確定性(技術(shù)的發(fā)展與開(kāi)發(fā)人員

14、對(duì)技術(shù)的理解程度都不同)由于交流障礙而引起的需求不確定性需求是持續(xù)變化的不斷的修改所帶來(lái)的錯(cuò)誤使得軟件退化人為和市場(chǎng)的風(fēng)險(xiǎn)軟件費(fèi)用、可靠性、生產(chǎn)率、重用問(wèn)題難以解決,21,講授內(nèi)容,軟件工程的基本概念基于計(jì)算機(jī)的系統(tǒng)工程軟件過(guò)程,22,1. 系統(tǒng)總體特性,功能特性非功能特性,如可靠性、安全性、保密性等。與系統(tǒng)總體可靠性緊密關(guān)聯(lián)的3個(gè)方面:硬件可靠性軟件可靠性操作可靠性,23,2. 系統(tǒng)及其環(huán)境,系統(tǒng)都是在一定的環(huán)

15、境中存在的。系統(tǒng)環(huán)境必將影響系統(tǒng)的功能和性能。環(huán)境包含一系列相互作用的其它系統(tǒng),有時(shí),環(huán)境可能被看作是一個(gè)獨(dú)立的系統(tǒng)。系統(tǒng)工程師一定要了解系統(tǒng)環(huán)境在許多情況下,系統(tǒng)的目的就是要改變環(huán)境。一個(gè)系統(tǒng)的功能要受到環(huán)境變化的影響,這種影響可能很難估計(jì)。,24,3. 系統(tǒng)建模,系統(tǒng)建模作為系統(tǒng)需求和設(shè)計(jì)活動(dòng)的一部分,描述組成系統(tǒng)的組件以及組件之間的關(guān)系(系統(tǒng)體系結(jié)構(gòu))系統(tǒng)體系結(jié)構(gòu)通常以方塊圖來(lái)描述。一個(gè)系統(tǒng)體系結(jié)構(gòu)可以以功能為單

16、位劃分成子系統(tǒng)或功能組件,而不必關(guān)心由硬件還是軟件實(shí)現(xiàn)。,25,功能組件可以分為六類(lèi):傳感器組件:收集來(lái)自系統(tǒng)環(huán)境的信息。執(zhí)行機(jī)構(gòu)組件:引起一些系統(tǒng)環(huán)境的變化。計(jì)算組件:給定輸入,執(zhí)行計(jì)算并產(chǎn)生輸出。通信組件:實(shí)現(xiàn)系統(tǒng)組件之間的彼此通信。調(diào)度組件:協(xié)調(diào)組件間的操作。接口組件:將一個(gè)組件中的表示轉(zhuǎn)換成另一個(gè)組件中的表示。,26,4. 系統(tǒng)工程過(guò)程,,,需求定義,系統(tǒng)設(shè)計(jì),組件開(kāi)發(fā),系統(tǒng)集成,系統(tǒng)安裝,系統(tǒng)進(jìn)化,系統(tǒng)退役,27,

17、系統(tǒng)需求定義注重三種類(lèi)型的需求:抽象的功能需求系統(tǒng)特性系統(tǒng)一定不能具有的性質(zhì)系統(tǒng)設(shè)計(jì)所包括的活動(dòng)有:分割需求(通常有多種分割方法,可以產(chǎn)生不同的方案)識(shí)別子系統(tǒng)為子系統(tǒng)分配需求(通常由于外購(gòu)COTS子系統(tǒng)帶來(lái)的限制而需要修改需求)描述子系統(tǒng)的功能定義子系統(tǒng)的接口,28,子系統(tǒng)開(kāi)發(fā)所常見(jiàn)的問(wèn)題:通??梢圆⑿虚_(kāi)發(fā)不同的子系統(tǒng)一些超出子系統(tǒng)范圍的修改經(jīng)常發(fā)生,但是對(duì)已經(jīng)實(shí)現(xiàn)的硬件工程的修改往往帶來(lái)非常昂貴的代價(jià),這時(shí)修改

18、往往落在軟件上(軟件的固有柔性,flexible),說(shuō)明軟件需求的變化更大更頻繁。系統(tǒng)集成最好采取增量式過(guò)程,其理由是:子系統(tǒng)的開(kāi)發(fā)時(shí)間通常無(wú)法預(yù)計(jì)增量式集成可以減少錯(cuò)誤定位的成本(錯(cuò)誤定位可能引起不同子系統(tǒng)的承包商之間的爭(zhēng)論,解決問(wèn)題的談判須花費(fèi)時(shí)日),29,講授內(nèi)容,軟件工程的基本概念基于計(jì)算機(jī)的系統(tǒng)工程軟件過(guò)程,30,1. 軟件過(guò)程模型,一個(gè)軟件過(guò)程模型是軟件過(guò)程的一個(gè)抽象表示。一般使用過(guò)程模型區(qū)分或解釋不同的軟件開(kāi)發(fā)

19、方法。在實(shí)際的軟件開(kāi)發(fā)中,很少單獨(dú)使用單一的過(guò)程模型,4類(lèi)軟件過(guò)程模型生命周期模型(瀑布模型)進(jìn)化式開(kāi)發(fā)模型形式化系統(tǒng)開(kāi)發(fā)模型面向復(fù)用的開(kāi)發(fā)模型,31,瀑布模型,瀑布模型(Waterfall)軟件生存周期模型(Classic Life Cycle Model)線(xiàn)性順序模型(Linear Sequential Model),32,瀑布模型的三個(gè)特點(diǎn),階段間具有順序性和依賴(lài)性推遲實(shí)現(xiàn)的觀(guān)點(diǎn)質(zhì)量保證的觀(guān)點(diǎn),33,瀑布模型的優(yōu)

20、點(diǎn),開(kāi)發(fā)過(guò)程基本上是線(xiàn)性順序的,便于管理基于“明確、完備的需求”,可以獲得好的開(kāi)發(fā)效果,34,Cost of changes,After release,,,The Impact of Changes,Definition,Development,1.5~6x,,,,,??????,1x,60~100x,35,Waterfall Model with Maintenance Circle,36,進(jìn)化式開(kāi)發(fā)模型,進(jìn)化式開(kāi)發(fā)的思想:基于

21、最初的需求,先開(kāi)發(fā)一個(gè)原型系統(tǒng)給用戶(hù)使用,然后,根據(jù)用戶(hù)的反饋意見(jiàn)不斷地修改這個(gè)系統(tǒng),直到形成最后成熟的軟件產(chǎn)品。所強(qiáng)調(diào)的是,需求可以不斷地被補(bǔ)充和完善。進(jìn)化式開(kāi)發(fā)有種方式探索式開(kāi)發(fā):其目標(biāo)是與用戶(hù)一起工作,共同探索需求,直到最后交付系統(tǒng)。拋棄式原型:開(kāi)發(fā)原型的目標(biāo)是理解用戶(hù)需求。,37,從工程學(xué)和管理學(xué)角度看,進(jìn)化式開(kāi)發(fā)有三方面的問(wèn)題:過(guò)程不可見(jiàn)系統(tǒng)結(jié)構(gòu)通常較差快速原型工具和技術(shù)往往與主流的工具和技術(shù)不相容實(shí)際使用的過(guò)程

22、模型通常是混合模型Waterfall Model with PrototypingV ModelPhased Development ModelIncremental and Iterative ModelSpiral Model,38,Waterfall Model with Prototyping,39,V-Model,40,Phased Development Model,41,The Incremental and

23、Iterative Model,,,,,,Incremental Development,Iterative Development,,,,42,Examples in Agile,43,增量開(kāi)發(fā)的優(yōu)點(diǎn),能在較短的時(shí)間內(nèi)向用戶(hù)提交可以完成主要功能的產(chǎn)品逐步增加產(chǎn)品的功能,使用戶(hù)有充裕的時(shí)間學(xué)習(xí)和適應(yīng)新產(chǎn)品,減少一個(gè)全新的產(chǎn)品給客戶(hù)組織帶來(lái)的沖擊,44,Spiral Model,45,螺旋模型的優(yōu)點(diǎn),有利于已有軟件的重用有助于把軟件質(zhì)

24、量作為軟件開(kāi)發(fā)的一個(gè)重要目標(biāo)減少了過(guò)多測(cè)試或測(cè)試不足所帶來(lái)的風(fēng)險(xiǎn)軟件維護(hù)與軟件開(kāi)發(fā)沒(méi)有本質(zhì)區(qū)別,46,統(tǒng)一過(guò)程(RUP),Rational Unified Process是 Rational 公司開(kāi)發(fā)和維護(hù)的過(guò)程產(chǎn)品。 RUP的突出特點(diǎn)用例驅(qū)動(dòng)(系統(tǒng)功能)以體系結(jié)構(gòu)/架構(gòu)為中心(表現(xiàn)形式)迭代和增量開(kāi)發(fā)(過(guò)程實(shí)施)由UML方法和工具支持,47,Iterative and incremental development

25、Use-case driven,,,,,Project Management,Environment,Business Modeling,Implementation,Test,Analysis & Design,Preliminary Iteration(s),Iter.#1,,,,,,,Phases,Process Workflows,Iterations,Supporting Workflows,Iter.#2,It

26、er.#n,Iter.#n+1,Iter.#n+2,Iter.#m,Iter.#m+1,Deployment,,,,Configuration & Change Mgmt,Requirements,,,,,Elaboration,Transition,Inception,Construction,48,2. 軟件描述,可行性研究需求導(dǎo)出和分析需求描述需求有效性驗(yàn)證,49,3. 軟件設(shè)計(jì)與實(shí)現(xiàn),體系結(jié)構(gòu)設(shè)計(jì)子系統(tǒng)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論