一 軟件工程的本質(zhì)
-
本質(zhì)
- 不同抽象層次之間的映射與轉(zhuǎn)換捧韵。任何軟件系統(tǒng)開(kāi)發(fā)的共同本質(zhì)在于:從現(xiàn)實(shí)空間的需求到計(jì)算空間的軟件代碼之間的映射與轉(zhuǎn)換。用嚴(yán)格的規(guī)范和管理手段來(lái)縮小偏差汉操,通過(guò)犧牲「時(shí)間」來(lái)提高「質(zhì)量」再来。
-
映射與轉(zhuǎn)換
- 單步映射與多步映射
軟件工程的兩個(gè)映射:「概念映射」是問(wèn)題空間的概念與解空間的模型化概念之間的映射;「業(yè)務(wù)邏輯映射」是問(wèn)題空間的處理邏輯與解空間處理邏輯之間的映射。
映射過(guò)程
映射過(guò)程包含需求分析芒篷、軟件設(shè)計(jì)搜变、實(shí)現(xiàn)、驗(yàn)證/確認(rèn)
二 軟件工程所關(guān)注的目標(biāo)
- 軟件工程所關(guān)注的對(duì)象
- 產(chǎn)品:各個(gè)抽象層次的產(chǎn)出物针炉;
- 過(guò)程 : 在各個(gè)抽象層次之間進(jìn)行映射與轉(zhuǎn)換挠他;
- 軟件工程具有「產(chǎn)品與過(guò)程二相性」的特點(diǎn),必須把二者結(jié)合起來(lái)去考慮篡帕,而不能忽略其中任何一方殖侵。
- 功能性需求(FR):軟件所實(shí)現(xiàn)的功能達(dá)到它的設(shè)計(jì)規(guī)范和滿足用戶需求的程度÷该纾考慮軟件的完備性愉耙、正確性、健壯性拌滋、可靠性朴沿。
- 非功能性需求(NFR): 系統(tǒng)能夠完成所期望的工作的性能與質(zhì)量“苌埃考慮軟件的效率赌渣、可用性、可維護(hù)性昌犹、可移植性坚芜、清晰性、安全性斜姥、兼容性鸿竖、經(jīng)濟(jì)性、商業(yè)質(zhì)量铸敏。
三 軟件開(kāi)發(fā)中的多角色
- 在軟件開(kāi)發(fā)過(guò)程中同樣需要多種角色之間緊密協(xié)作缚忧,才能提高質(zhì)量、高效率的完成任務(wù)
-
顧客企業(yè)(Client 甲方)
- 決策者(CxO)杈笔、終端用戶(End User)闪水、系統(tǒng)管理員
-
軟件開(kāi)發(fā)公司(Supplier,乙方)
- 決策者(CxO)蒙具;
- 軟件銷(xiāo)售與市場(chǎng)人員球榆;
- 咨詢師、需求分析師禁筏;
- 軟件架構(gòu)師持钉、軟件設(shè)計(jì)師;
- 開(kāi)發(fā)人員:開(kāi)發(fā)經(jīng)理/項(xiàng)目經(jīng)理融师、程序員右钾;
- 維護(hù)人員
四 軟件工程=最佳實(shí)踐
- 軟件系統(tǒng)的復(fù)雜性、動(dòng)態(tài)性:
高深的軟件理論在軟件開(kāi)發(fā)中變得無(wú)用武之地 - 軟件工程被看做一種實(shí)踐的藝術(shù)
五 軟件工程的核心概念
復(fù)用
在一個(gè)新系統(tǒng)中,大部分的內(nèi)容是成熟的舀射,只有小部分內(nèi)容是全新的
構(gòu)造新的軟件系統(tǒng)可以不必每次從零做起窘茁;
直接使用已有的軟構(gòu)件,即可組裝成新的系統(tǒng)脆烟;
復(fù)用已有的功能模塊山林,既可以提高開(kāi)發(fā)效率,也可以改善新開(kāi)發(fā)過(guò)程
中帶來(lái)的質(zhì)量問(wèn)題邢羔。分治
將復(fù)雜問(wèn)題分解為若干可獨(dú)立解決的簡(jiǎn)單子問(wèn)題驼抹,并分別獨(dú)立求解,
以降低復(fù)雜性拜鹤;然后再將各子問(wèn)題的解綜合起來(lái)框冀,形成最初復(fù)雜問(wèn)題的解。
核心問(wèn)題:如何的分解策略可以使得軟件更容易理解敏簿、開(kāi)發(fā)和維護(hù)明也?
折中
不同的需求之間往往存在矛盾與沖突,需要通過(guò)折中來(lái)作出的合理的
取舍惯裕,找到使雙方均滿意的點(diǎn)温数。核心問(wèn)題:如何調(diào)和矛盾(需求之間、人與人之間蜻势、供需雙方之間撑刺,等等)
-
演化
- 軟件系統(tǒng)在其生命周期中面臨各種變化
- 核心問(wèn)題:在設(shè)計(jì)軟件的初期,就要充分考慮到未來(lái)可能的變化握玛,并
采用恰當(dāng)?shù)脑O(shè)計(jì)決策够傍,使軟件具有適應(yīng)變化的能力。
六 總結(jié)
由于規(guī)模挠铲、復(fù)雜度王带、變化、接口的增多市殷,時(shí)間、成本的逐漸上升刹衫,軟件的質(zhì)量不斷下降引發(fā)了軟件危機(jī)醋寝。因而出現(xiàn)了「軟件工程」。有這樣一個(gè)公式:SE = 過(guò)程+方法+工具 這樣的一個(gè)公式保證了軟件的質(zhì)量带迟。我們需要把握住的一個(gè)中心就是軟件工程的本質(zhì):不同抽象層次之間的映射與轉(zhuǎn)換音羞。其中有單步映射和多步映射,單步映射一步到位仓犬,而多步映射則要分幾步完成嗅绰,通過(guò)犧牲「時(shí)間」提高了「質(zhì)量」。
而軟件工程所要達(dá)到的質(zhì)量目標(biāo)主要有兩種:功能需求(FR)和非功能需求(NFR)。并且軟件工程等同于最佳的實(shí)踐窘面,任何理論的方法都需經(jīng)過(guò)實(shí)踐的檢驗(yàn)方能證明為有效的方法翠语。此外還有軟件工程的核心概念:復(fù)用、分治财边、折中肌括、演化等等。