版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、第一章1.1什么是計算機軟件?軟件的特點是什么?計算機軟件是指計算機系統(tǒng)中的程序及其文檔軟件的特點:軟件是一種邏輯實體,而不是有形的系統(tǒng)元件,其開發(fā)成本和進度難以準確地估算。軟件是被開發(fā)的或被設計的,沒有明顯的制造過程, 一旦開發(fā)成功,只需復制即可,但其維護的工作量大。軟件的使用沒有硬件那樣的機械磨損和老化問題。1.2 簡述軟件的分類,并舉例說明1 .系統(tǒng)軟件系統(tǒng)軟件居于計算機系統(tǒng)中最接近硬件的一層,其他軟件一般都通過系統(tǒng)軟件發(fā)揮 作用。例如:編譯軟件、操作系統(tǒng)。2 .支撐軟件支撐軟件是支撐軟件的開發(fā)和維護的軟件。例如:數(shù)據(jù)庫管理系統(tǒng)、網(wǎng)絡軟件、軟 件工具、軟件開發(fā)環(huán)境。3 .應用軟件應用軟件
2、是特定應用領域?qū)S玫能浖?。例如:工?科學計算機軟件、嵌入式軟件、產(chǎn)品線軟件、 Web應用軟件、人工智能軟件。1.3 簡述軟件語言的分類,并舉例說明。1 .需求定義語言是用于書寫軟件需求定義的語言。例如:PSL/PSA2 .功能性語言是用于書寫軟件功能規(guī)約的語言,通常又稱為功能規(guī)約語言。例如:廣譜語言、Z3 .設計性語言是用于書寫軟件設計規(guī)約的語言。例如:PDL。4 .實現(xiàn)性語言也稱為程序設計語言,是用于書寫計算機程序的語言。例如:C java、PROLOGFORTRAN COBOL Modula。5 .文檔語言是用于書寫軟件文檔的語言。通常用自然語言或半形式化語言書寫。1.4 什么是軟件工程
3、?軟件工程是應用計算機科學、數(shù)學及管理科學等原理,開發(fā)軟件的工程。軟件工程借鑒 傳統(tǒng)工程的原則、方法,以提高質(zhì)量、降低成本為目的。1.5 簡述軟件工程的基本原則。軟件工程原則包括圍繞工程設計、工程支持和工程管理所提出的以下4條基本原則。1 .選取適宜的開發(fā)模型必須認識需求定義的易變性,采用適宜的開發(fā)模型, 保證軟件產(chǎn)品滿足用戶的要求。2 .采用合適的設計方法合適的設計方法有助于這些特征的實現(xiàn),以達到軟件工程的目標。3 .提供高質(zhì)量的工程支撐軟件工程項目的質(zhì)量與開銷直接取決于對軟件工程所提供的支撐質(zhì)量和效用。4 .重視軟件工程的管理僅當軟件過程予以有效管理時,才能實現(xiàn)有效的軟件工程。1.6 軟件
4、工程生存周期分哪幾個階段?分別簡述各個階段的任務。1 .計算機系統(tǒng)工程計算機系統(tǒng)工程的任務是確定待開發(fā)軟件的總體要求和范圍,以及該軟件與其他計算機系統(tǒng)元素之間的關系,進行成本估算,作出進度安排,并進行可行性分析。2 .需求分析需求分析主要解決待開發(fā)軟件要“做什么”的問題,確定軟件的功能、性能、 數(shù)據(jù)、界面等要求,生成軟件需求規(guī)約(也稱軟件需求規(guī)格說明)。3 . 設計 系統(tǒng)設計的任務是設計軟件系統(tǒng)的體系結構,詳細設計的任務是設計各個組成成分的實現(xiàn)細節(jié),包括局部數(shù)據(jù)結構和算法。4 . 編碼 編碼階段的任務是用某種程序設計語言,將設計的結果轉(zhuǎn)換為可執(zhí)行的程序代碼。5 .測試測試階段的任務是發(fā)現(xiàn)并糾正
5、軟件中的錯誤和缺陷。1.7 簡述CMM的5個等級。1. 初始級2. 可重復級3. 已定義級4. 已管理級5. 優(yōu)化級1.8 簡述CMMI的連續(xù)式模型和階段式模型。1 .階段式模型的結構類同于軟件CMM ,它關注組織的成熟度,CMMI-SE/SW/IPPD 1.1版中有5個成熟度等級:初始的、已管理的、已定義的、定量管理的、優(yōu)化的。2 .連續(xù)式模型關注每個過程域的能力,CMMI中包括6個過程域能力等級:未完成的、已執(zhí)行的、已管理的、已定義的、定量管理的、優(yōu)化的。1.9 簡述各類軟件過程模型的特點。1 .瀑布模型:上一階段的活動完成并經(jīng)過評審才能開始下一階段的活動,接受上一階段活動的結果作為本階段
6、活動的輸入,依據(jù)上一階段活動的結果實施本階段應完成的活動,對本階段的活動進行評審。2 .演化模型:從結構初始的原型出發(fā),逐步將其演化成最終軟件產(chǎn)品的過程。演化模型特別適用于對軟件需求缺乏準確認識的情況。3 .增量模型:將軟件的開發(fā)過程分為若干個日程時間交錯的線性序列,融合了瀑布模型的基本成分(重復地應用)和演化模型的迭代特征,特別適用于需求經(jīng)常發(fā)生變化的軟件開發(fā)。4 .原型模型:開發(fā)人員和用戶在原型”上達成一致,縮短了開發(fā)周期,加快了工程進度,降低成本。5 .螺旋模型:將原型實現(xiàn)的迭代特征與瀑布模型中控制的和系統(tǒng)化的方面結合起來, 不僅體現(xiàn)了這兩種模型的優(yōu)點,而且增加了風險分析。6 .噴泉模型
7、:各個階段沒有明顯的界限,開發(fā)人員可以同步進行開發(fā),可以提高軟件項目開發(fā)效率,節(jié)省開發(fā)時間,適應于面向?qū)ο蟮能浖_發(fā)過程。7 .基于構件的開發(fā)模型:利用預先包裝的構件來構造應用系統(tǒng)。8 .形式化方法模型:易于發(fā)現(xiàn)需求的歧義性、不完整性和不一致性,易于對分析模型、 設計模型和程序進行驗證。1.10 敏捷軟件開發(fā)的特點是什么?1 .個體和交互勝過過程和工具2 .可以工作的軟件勝過面面俱到的文檔3 .客戶合作勝過合同談判4 .響應變化勝過遵循計劃1.11 簡述敏捷軟件開發(fā)的價值觀。1 .個人和交互高于過程和工具2 .可運行軟件高于詳盡的文檔3 .與客戶協(xié)作高于合同(契約)談判4 .對變更及時作出反應
8、高于遵循計劃1.12 簡述敏捷軟件開發(fā)的原則。1 .最優(yōu)先的是通過盡早地和不斷地交有價值的軟件來使客戶滿意。2 .即使到了開發(fā)的后期,也歡迎改變需求。3 .以幾周到幾個月為周期,盡快、不斷地發(fā)布可運行軟件。4 .在整個項目過程中,業(yè)務人員和開發(fā)人員必須天天一起工作。5 .以積極向上的員工為中心建立項目組,給予他們所需要的環(huán)境和支持,對他們的工作 予以充分的信任。6 .項目組內(nèi)效率最高、最有效的信息傳遞方式是面對面的交談。7 .測量項目進展的首要依據(jù)是可運行的軟件。8 .敏捷過程提倡可持續(xù)的開發(fā),項目發(fā)起者、開發(fā)者和用戶應能長期保持恒定的速度。9 .應時刻關注技術上的精益求精和好的設計,以增強敏
9、捷性。10 .簡單化是必不可少的,這是盡可能減少不必要工作的藝術。11 .最好的構架、需求和設計出自于自我組織的團隊。12 .團隊要定期反思怎樣才能更有效,并據(jù)此調(diào)整自己的行為。1.13 通過本章學習,請對敏捷軟件開發(fā)作簡要評價。(略)1.14 簡述CASET具和環(huán)境的重要性。CASE已被證明可以加快開發(fā)速度,提高應用軟件生產(chǎn)率并保證應用軟件的可靠品質(zhì)。計算機專業(yè)人員利用計算機使他們的企業(yè)提高了效率,企業(yè)的各個部門通過使用計算機提高了生產(chǎn)率和效率=,增強了企業(yè)的競爭力并使之帶來了更多的利潤。第二章2.1 簡述系統(tǒng)工程的任務成本估算,并作出進度安排。4.可行性分析主要從經(jīng)濟、技術、法律等方面分析
10、所給出的解決方案是否可行。5.生成系統(tǒng)規(guī)格說明作為以后開發(fā)基于計算機的系統(tǒng)的依據(jù)。2.2 基于計算機的系統(tǒng)由哪些元素組成?1 .軟件2 . 硬件3 .人員4 .數(shù)據(jù)庫5 . 文檔6 . 規(guī)程2.3簡述可行性分析的任務1 . 經(jīng)濟可行性a) 成本b) 效益c)貨幣的時間價值d)投資的回收期e) 純收入2 . 技術可行性a)風險分析b)資源分析c)技術分析3 .法律可行性4 .方法的選擇和折衷第三章3.1需求工程的重要性是什么?可以確定客戶需求幫助分析人員理解問題評估可行性 協(xié)商合理的解決方法 無歧義的規(guī)約方案、確認規(guī)約以及將規(guī)約轉(zhuǎn)換到可運行的系統(tǒng)時的管理要求。3.2需求工程具體包括哪些步驟?每個
11、步驟的具體任務是什么?3.3 一個系統(tǒng)分析員應該具備哪些思想素質(zhì)和基本知識?請說明理由。1.2.3.4.5.6.具有良好的書面和口頭交流表達能力。3.4 列出在制定需求獲取策略時的3種主要考慮因素。1 .功能需求??紤]系統(tǒng)要做什么,在何時做,在何時及如何修改或升級。2 .性能需求??紤]軟件開發(fā)的技術性指標。3 .用戶或人對因素??紤]用戶的類型。3.5 (略)3.6 舉例說明一個系統(tǒng)的 3個不同類型的非功能需求答:非功能性需求是指軟件產(chǎn)品為滿足用戶業(yè)務需求而必須具有且除功能需求以外的特性。軟件產(chǎn)品的非功能性需求包括系統(tǒng)的性能、可靠性、可維護性、可擴充性和對技術和對業(yè)務的適應性等。例如在銀行管理系
12、統(tǒng)中,由于銀行數(shù)據(jù)量的龐大以及對銀行賬戶 的管理需求,用戶對系統(tǒng)的性能、可靠性、可維護性要求很高。安全性是對銀行用戶個 人信息保密的基本要求;在使用系統(tǒng)時,由于用戶龐大,要求能快速安全的執(zhí)行要求, 這就對系統(tǒng)的性能有高需求;銀行的用戶的變動比較大,需求高要求的系統(tǒng)維護。3.7 (略)3.8 軟件需求分析的操作性原則和需求工程的指導性原則是什么?需求分析的操作性原則:必須能夠表示和理解問題的信息域。必須能夠定義軟件將完成的功能。必須能夠表示軟件的行為(作為外部事件的結果)。必須劃分描述數(shù)據(jù)、功能和行為的模型,從而可以分層次地揭示細節(jié)。分析過程應該從要素信息轉(zhuǎn)移向細節(jié)信息需求工程的指導性原則:I在
13、開始建立分析模型之前應當先理解問題。如果問題沒有很好理解就急于求成,常常會產(chǎn)生一個解決錯誤問題的完美的軟件。強力推薦使用原型。這樣做可以使用戶了解將如何與計算機交互,而人們對軟件質(zhì)量的認識常常是基于對界面“友好性”的切身體會。記錄每一個需求的起源和原因。這是建立對用戶要求的可追溯性的第一步。使用多個視圖,建立系統(tǒng)的數(shù)據(jù)、功能和行為模型。這樣做可幫助分析員從多方面分析和理解問題,減少遺漏,識別可能的不一致之處。二I給需求賦予優(yōu)先級。因為過短的時限會減少實現(xiàn)所有軟件需求的可能性。因此,對需求排定一個優(yōu)先次序,標識哪些需求先實現(xiàn),哪些需求后實現(xiàn)。注意消除歧義性。因為大多數(shù)需求都是以自然語言描述,存在
14、敘述的歧義性問題造成遺漏和誤解。采用正式的技術評審是發(fā)現(xiàn)和消除歧義性的好方法。3.9 軟件需求規(guī)約主要包括哪些內(nèi)容?1 .引言2 .信息描述3 .功能描述4 .行為描述5 .檢驗標準6 .參考書目7 .附錄 3.10需求驗證應該有哪些人參加?分析人員、用戶、開發(fā)部門的管理者、軟件設計、實現(xiàn)、測試的人員。第四章4.1 簡述軟件設計階段的基本任務。1 .數(shù)據(jù)/類設計:將分析類模型變換成類的實現(xiàn)和軟件實現(xiàn)所需要的數(shù)據(jù)結構。2 .體系結構設計:定義了軟件的整體結構,由軟件部件、外部可見的屬性和他們之間的關系組成。3 .接口設計:描述了軟件內(nèi)部、軟件和協(xié)作系統(tǒng)之間以及軟件同人之間的通信方式。4 .部件級
15、設計:將軟件體系結構的結構性元素變換為對軟件部件的過過程性描述。4.2 軟件設計與軟件質(zhì)量的關系是怎么樣的?設計是在軟件開發(fā)中形成質(zhì)量的階段,設計提供了可以用于質(zhì)量評估的軟件表示,是將用戶需求準確地轉(zhuǎn)化為完整的軟件產(chǎn)品或系統(tǒng)的主要途徑。4.3 (略)4.4 簡述模塊、模塊化及模塊化設計的概念。模塊是數(shù)據(jù)說明、可執(zhí)行語句等程序?qū)ο蟮募希菃为毭?,并且可以通過名字來訪問的。模塊化是指把軟件按照規(guī)定原則,劃分為一個個較小的, 相互獨立的但又相互關聯(lián)的部件。模塊化設計就是程序的編寫不是開始就逐條錄入計算機語句和指令,而是首先用主程序、子程序、子過程等框架把軟件的主要結構和流程描述出來,并定義和調(diào)
16、試好各個框架之間的輸入、輸出鏈接關系。4.5 舉例說明每種類型的模塊耦合度和每種類型的模塊內(nèi)聚度。a)內(nèi)容耦合:當一個模塊直接修改或操作另一個模塊的數(shù)據(jù),或者直接轉(zhuǎn)入另一個模塊時就發(fā)生了內(nèi)容耦合。此時,被修改的模塊完全依賴于修改它的模塊。如果發(fā)生下列情形,兩個模塊之間就發(fā)生了內(nèi)容耦合:i. 一個模塊直接訪問另一個模塊的內(nèi)部數(shù)據(jù)ii. 一個模塊不通過正常入口轉(zhuǎn)到另一模塊內(nèi)部iii. 兩個模塊有一部分程序代碼重疊(只可能出現(xiàn)在匯編語言中)iv. 一個模塊有多個入口。b)公共耦合:若一組模塊都訪問同一個公共數(shù)據(jù)環(huán)境,則它們之間的耦合就稱為公共耦合。公共的數(shù)據(jù)環(huán)境可以是全局數(shù)據(jù)結構、共享的通信區(qū)、內(nèi)存
17、的公共覆蓋區(qū)等。c)外部耦合:一組模塊都訪問同一全局簡單變量而不是同一全局數(shù)據(jù)結構,而且不是通過參數(shù)表傳遞該全局變量的信息,則稱之為外部耦合。d)控制耦合:如果一個模塊通過傳送開關、標志、名字等控制信息, 明顯地控制選擇另一模塊的功能,就是控制耦合。e)標記耦合:一組模塊通過參數(shù)表傳遞記錄信息,就是標記耦合。這個記錄是某一數(shù)據(jù)結構的子結構,而不是簡單變量。其實傳遞的是這個數(shù)據(jù)結構的地址。f) 數(shù)據(jù)耦合:一個模塊訪問另一個模塊時,彼此之間是通過簡單數(shù)據(jù)參數(shù)(不是控制參數(shù)、公共數(shù)據(jù)結構或外部變量 )來交換輸入、輸出信息的。g)非直接耦合:兩個模塊之間沒有直接關系,它們之間的聯(lián)系完全是通過主模塊的控
18、制和調(diào)用來實現(xiàn)的1,巧合內(nèi)聚:講幾個模塊中沒有明確表現(xiàn)出獨立功能的相同程序代碼段獨立出來建立 的模塊稱巧合內(nèi)聚模塊。2 .邏輯內(nèi)聚:邏輯內(nèi)聚是指完成一組邏輯相關任務的模塊,調(diào)用該模塊時,由傳送給模塊的控制性參數(shù)來確定該模塊應執(zhí)行哪一種功能。3 .時間內(nèi)聚:時間內(nèi)聚是指一個模塊中的所有任務必須在同一時間段內(nèi)執(zhí)行。4 .過程內(nèi)聚:過程內(nèi)聚是指一個模塊完成多個任務,這些任務必須指定的過程執(zhí)行。5 .通信內(nèi)聚:通信內(nèi)聚是指一個模塊內(nèi)所有處理元素都集中在某個數(shù)據(jù)結構的一塊區(qū) 域中。6 .順序內(nèi)聚:順序內(nèi)聚是指一個模塊完成多個功能,這些功能又必須順序執(zhí)行7 .功能內(nèi)聚:功能內(nèi)聚是指一個模塊中各個部分都是為
19、完成一項具體功能而協(xié)同工 作,緊密聯(lián)系不可分割。4.6 耦合和軟件可移植性的概念有何關系?耦合性是2個或多個模塊相關的程度,可移植性是指軟件從一個平臺/環(huán)境轉(zhuǎn)移到另一個平臺/環(huán)境的難易程度。4.7 描述信息隱蔽概念,并討論信息隱蔽與模塊獨立兩概念之間的關系。1 .信息隱蔽指在設計和確定模塊時,使得一個模塊內(nèi)包含信息(過程或數(shù)據(jù)),對于不需要這些信息的其他模塊來說,是不能訪問的。在面向?qū)ο蠓椒ㄖ?,信息隱蔽是通過對象的封裝性來實現(xiàn)的。2 .信息隱蔽的概念與模塊的獨立性直接相關4.8 什么是模塊的獨立性?設計中為什么模塊要獨立?如何度量獨立性?模塊功能獨立有何 優(yōu)點?1. 模塊獨立性:A.模塊獨立性
20、指每個模塊只完成系統(tǒng)要求的獨立的子功能,并且與其他模塊的聯(lián)系最少且接口簡單B.模塊獨立性是指模塊內(nèi)部各部分及模塊間的關系的一種衡量標準,由內(nèi)聚和耦合來度量。2. A.具有獨立的模塊的軟件比較容易開發(fā)出來。這是由于能夠分割功能而且接口可以簡化,當許多人分工合作開發(fā)同一個軟件時,這個優(yōu)點尤其重要。B.獨立的模塊比較容易測試和維護。 這是因為相對說來 修改設計和程序需要的工 作量比較小,錯誤傳播范圍小,需要擴充功能時能夠 "插入"模塊。總之,模塊獨立 是優(yōu)秀設計的關鍵,而設計又是決定軟件質(zhì)量的關鍵環(huán)節(jié)。3. 模塊的獨立程度可以由兩個定性標準度量:內(nèi)聚和耦合。4. A.具有獨立的模
21、塊的軟件比較容易開發(fā)出來。這是由于能夠分割功能而且接口可以簡化,當許多人分工合作開發(fā)同一個軟件時,這個優(yōu)點尤其重要。B.獨立的模塊比較容易測試和維護。4.9 軟件設計規(guī)約主要包括哪些內(nèi)容?1 .工作范圍A.系統(tǒng)目標B.運行環(huán)境C.主要軟件需求D.設計約束/限制2 .體系結構設計A.數(shù)據(jù)流與控制流復審B.導出的程序結構C.功能與程序交叉索引3 .數(shù)據(jù)設計A.數(shù)據(jù)對象與形成的數(shù)據(jù)結構B.文件和數(shù)據(jù)庫結構:i.文件的邏輯結構;ii.文件邏輯記錄描述;iii.訪問方式C.全局數(shù)據(jù)D.文件/數(shù)據(jù)與程序交叉索引4 .接口設計A.人機界面規(guī)格說明B.人機界面設計規(guī)則C.外部接口設計:i.外部數(shù)據(jù)接口;ii.
22、外部系統(tǒng)或設備接口D.內(nèi)部接口設計規(guī)則5 .各部件的過程設計A.處理與算法描述B.接口描述C.設計語言(或其他)描述D.使用的部件E.內(nèi)部程序邏輯描述F.注釋/約束/限制6 . 運行設計A.運行部件組合B.運行控制C.運行時間7 .出錯處理設計A.出錯處理信息B.出錯處理對策:i.設置后備;ii.性能降級;iii.恢復和再啟動8 .安全保密設計9 .需求/設計交叉索引10 .測試部分A.測試方針B.集成策略C.特殊考慮11 .特殊注解12 .附錄第五章5.1 簡述數(shù)據(jù)流圖的主要思想,概述使用數(shù)據(jù)流圖進行需求分析的過程。數(shù)據(jù)流圖描述輸入數(shù)據(jù)流到輸出數(shù)據(jù)流的變換(即加工),用于對系統(tǒng)的功能建模。1
23、 .畫出系統(tǒng)的輸入和輸出A.確定源和宿B.確定加工C.確定數(shù)據(jù)流D.頂層圖通常沒有文件2 .畫出系統(tǒng)內(nèi)部A.確定加工B.確定數(shù)據(jù)流C.確定文件D.確定源和宿3 . 畫出加工內(nèi)部4 .重復第3步,直至每個尚未分解的加工都足夠簡單(即不必再分解)5.2 分別采用數(shù)據(jù)流方法中的哪些技術來完成用戶需求的精確化、一致化和完全化任務?1 .父圖和子圖平衡2 .數(shù)據(jù)守恒3 . 局部文件4 . 一個加工的輸入數(shù)據(jù)流不能與該加工的輸入數(shù)據(jù)流同名5 .每個加工至少有一個輸入數(shù)據(jù)流和一個輸出數(shù)據(jù)流6 .在整套分層數(shù)據(jù)流中,每個文件應至少有一個加工讀該文件,有另一個加工寫該文件。7 .分層數(shù)據(jù)流圖中得每個數(shù)據(jù)流和文件
24、都必須命名(除了流入或流出文件的數(shù)據(jù)流)并且與數(shù)據(jù)字典一致。8 .分層DFD中的每個基本加工(即不再分解子圖的加工)都應有一個加工規(guī)約。5.3 (略)5.4 在數(shù)據(jù)流圖中,可否將兩個加工用一個數(shù)據(jù)流相連?可否將兩個源用一個數(shù)據(jù)流相連? 為什么?兩個加工可以直接用數(shù)據(jù)流相連,兩個源不能直接用數(shù)據(jù)流相連。因為數(shù)據(jù)流由一組固定成分的數(shù)據(jù)組成。在 DFD中,數(shù)據(jù)流的流向可以有以下幾種:從一個加工劉向另一個加 工,從加工流向文件(寫文件),從文件流向加工(讀文件),從源流向加工,從加工流向宿。5.5 (略)5.6 (略)5.7采用結構化分析方法寫出書店管理系統(tǒng)的需求文檔,包括數(shù)據(jù)流圖及數(shù)據(jù)字典。2、數(shù)據(jù)
25、字典存書數(shù)據(jù)字典:屬性名類型長度備注書號char10書的編號書名char30書的名稱作者char20書的寫作者類型char20書的類型簡述char150書的簡單介紹單價smallmoney4書的價格現(xiàn)存數(shù)量int4店內(nèi)的現(xiàn)有存書數(shù)量店內(nèi)位置char20書在店內(nèi)的具體位置出版社號char10出版社的編P特價書char2|是否為特價書(缺省值是“否”)出版社數(shù)據(jù)字典:屬性名類型長度備注出版小char10出版社的編R出版社名稱char20出版社的名稱所在城巾char10:出版社所在的城市1電話char15出版社的聯(lián)系電話進貨數(shù)據(jù)字典:屬性名類型長度備注書號char10P書的編號進價smallmone
26、y4書的進價進貨數(shù)量1int4;每本書的進貨數(shù)量1日期datetime8進貨的日期銷售數(shù)據(jù)字典:屬性名類型長度備注日期datetime8售貨的日期書號char10書的編號銷int4售出的書本數(shù)量銷售金額money8銷售金額-(單價*銷售量)會員信息數(shù)據(jù)字典:屬性名類型長度備注客服號char8:會員卡的卡號姓名char20會員的姓名地址char50會員的家庭住址電話char15:會員的電話號碼購買書號char10書的編號店內(nèi)收出數(shù)據(jù)字典:屬性名長度備注月份6水電支出4水電費用員工:支出4員工的工資其他支出4其他費用支出結算8每月的總結算5.10第六章6.1 簡述面向數(shù)據(jù)結構方法的特點答:特點如下
27、:1以信息對象及其操作作為核心進行需求分析;2認為復合信息對象具有層次結構,并且可按順序,選擇,重復3種結構分解為成員對象信3提供由層次信息結構映射為程序結構的機制,從而為軟件設計奠定良好的基礎。6.2 采用Jackson圖表示下面的文件結構:第七章(略)第八章8.1 什么是構件?答:根據(jù) pressman書中 的定義構件是某系統(tǒng)中有價值的、幾乎獨立的并可替換的一個部分,它在良好定義的體系結構語境內(nèi)滿足某種清晰的功能。根據(jù)brown的定義構件是一個獨立發(fā)布的功能部分,可以通過其接口訪問它的服務。根據(jù)計算機科學技術百科全書(第二版)中的定義軟件構件是軟件系統(tǒng)中具有相對獨立功能,可以明確標識,接口
28、由規(guī)約指定,與語境有明顯依賴關系,可獨立部署,且多由第三方提供的可組裝軟件實體。軟件構件須承載有用的功能,并遵循某種構件模型??蓮陀脴嫾侵妇哂锌蓮陀脙r值的構件。在基于構件的軟件開發(fā)中經(jīng)常會使用到的商用成品構件,是指由第三方開發(fā)的滿足一定構件標準并且可組裝的軟件構件。8.2 簡述基于構件的軟件開發(fā)過程?;跇嫾能浖_發(fā)過程:領域工程的步驟:1領域分析2建立領域特定的基準體系結構模型3標識候選構件4泛化和可變性分析5 構件重構6構件的測試7構件的包裝8構件入庫應用系統(tǒng)工程的步驟:1建立應用系統(tǒng)的體系結構模型;2尋找候選構件;3評價和選擇合適的構件;4構件的修改和特化;5開發(fā)未被復用的不分;6構
29、件的組裝;7集成測試;8評價被復用的構件,并推薦可能的新構件。第九章(略)第十章(略)第十一章11.1 軟件測試的目的是什么?軟件測試的目的是發(fā)現(xiàn)軟件中的錯誤和缺陷,并加以糾正。11.2 什么是白盒測試?什么是黑盒測試?白盒測試又稱結構測試, 這種方法把測試對象看做一個透明的盒子,測試人員根據(jù)程序內(nèi)部的邏輯結構及有關信息設計測試用例,檢查程序中所有邏輯路徑是否都按預定的要求正確地工作。白盒測試主要用于對程序模塊的測試。包括:程序模塊中的所有獨立路徑至少執(zhí)行一次。對所有邏輯判定的取值(“真”與“假”)都至少測試一次。在上下邊界及可操作范圍內(nèi)運行所有循環(huán)測試內(nèi)部數(shù)據(jù)結構的有效性等黑盒測試又稱行為測
30、試,這種方法吧測試對象看做一個黑盒子, 測試人員完全不考慮程 序內(nèi)部的邏輯結構和內(nèi)部特性, 只依據(jù)程序的需求規(guī)格說明書, 檢查程序的功能是否符 和它的功能需求。黑盒測試可用于各種測試,它試圖發(fā)現(xiàn)以下類型的錯誤:不正確或遺漏的功能接口錯誤,如輸入輸出參數(shù)的個數(shù)、類型等數(shù)據(jù)結構錯誤或外部信息(如外部數(shù)據(jù)庫)訪問錯誤性能錯誤初始化和終止錯誤11.3解:判定覆蓋:(1) X=85,Y=85(2) X=70 , Y=95(3) X=30 , Y=95條件覆蓋:(1) X=85 , X=85(3) X=95 , Y=50(4) X=50 , Y=95(5) X=40 , Y=40判定條件覆蓋:(1)X=8
31、5 ,X=85(2)X=70 ,Y=75(3)X=95 ,Y=50(4)X=50 ,Y=95(5)X=40 ,Y=40(6 )X=20 ,Y=95(7 )X=95 ,Y=20條件組合覆蓋:(1)X=85 ,X=85(2)X=65 ,Y=85(3 )X=85 ,Y=65(4 )X=70 ,Y=75(5 )X=95 ,Y=50(6 )X=50 ,Y=95(7 )X=40 ,Y=40路徑覆蓋:(1) X=85,Y=85(2) X=70 , Y=95(3) X=30 , Y=7011.4 (略)11.5 分別簡述單元測試、集成測試、確認測試和系統(tǒng)測試的任務。1 .單元測試:又稱模塊測試,著重對軟件設計
32、的最小單元一一軟件構件或模塊進行驗 證。單元測試根據(jù)設計描述,對重要的控制路徑進行測試,已發(fā)現(xiàn)構建或模塊內(nèi)部的錯誤,通常采用白盒測試,并且多個構件或模塊可以并行測試。單元測試的主要內(nèi)容:接口、局部數(shù)據(jù)結構、邊界條件、獨立路徑和錯誤處理路徑。2 .集成測試:也叫組裝測試或聯(lián)合測試。在單元測試的基礎上, 將所有模塊按照要求(如根據(jù)結構圖)組裝成為子系統(tǒng)或系統(tǒng), 進行集成測試。使用黑盒測試方法測試 集成的功能,并且對以前的集成進行回歸測試。3 .確認測試:經(jīng)集成測試后,已經(jīng)按照設計把所有的模塊組裝成一個完整的軟件系統(tǒng), 接口錯誤也已經(jīng)基本排除了,接著就應該進一步驗證軟件的有效性,這就是確認測試的任務
33、,即軟件的功能和性能如同用戶所合理期待的那樣。4 .系統(tǒng)測試:將已經(jīng)確認的軟件、計算機硬件、外設、網(wǎng)絡等其他元素結合在一起, 進行信息系統(tǒng)的各種組裝測試和確認測試,系統(tǒng)測試是針對整個產(chǎn)品系統(tǒng)進行的測試,目的是驗證系統(tǒng)是否滿足了需求規(guī)格的定義,找出與需求規(guī)格不符或與之矛盾的地方,從而提高更加完善的方案。11.6 什么是“測試?什么是3測試?1. a測試時由一個用戶在開發(fā)者的場所進行的測試,軟件在開發(fā)者對用戶的“指導下”進行測試。經(jīng)過a測試后的軟件成為3版軟件。2. 3測試是指軟件開發(fā)公司組織各方面的典型用戶在日常工作中實際使用3版本,并要求用戶報告異常情況、 提出批評意見,然后軟件開發(fā)公司再對3
34、版本進行改錯和11.7 什么是回歸測試?以確保對程序的改變和修改,沒回歸測試就是對已經(jīng)進行過的測試的子集的重新執(zhí)行, 有傳播非故意的副作用。11.8 簡述邊界值分析方法的作用。長期的測試工作經(jīng)驗告訴我們,大量的錯誤時發(fā)生在輸入或輸出范圍的邊界上,而不是發(fā)生在輸入輸出范圍的內(nèi)部。因此針對各種邊界情況設計測試用例,可以查出更多的錯誤。第十二章(略)第十三章13.1 請討論時軟件維護成本居高不下的因素。如何盡可能降低這些因素的影響?1.a)軟件的維護周期長;b)需要維護的軟件往往沒有文檔、或文檔資料嚴重不足、 或軟件的變化未在相應的文檔中反映出來;c)維護活動占用了其它軟件開發(fā)可用的資源,使資源的利
35、用率降低;d) 一些修復或修改請求得不到及時安排,使得客戶滿意率下降;e)維護的結果把一些新的潛在的錯誤引入軟件,降低了軟件質(zhì)量;f) 將軟件人員抽調(diào)到維護工作中,使得其他軟件開發(fā)過程受到干擾。2.a)確定質(zhì)量管理目標和優(yōu)先級;b)使用提高軟件質(zhì)量的技術和工具;c)選擇可維護性高的程序設計語言;d)完善程序文檔;e)進行質(zhì)量保證審查13.2 (略)13.3 軟件維護過程是如何進行的?為什么要進行軟件可維護性分析?1 .軟件維護過程包括: 建立維護組織;確定維護過程;保管維護記錄;進行維護評價 等四個階段。2 .可維護性是指理解、改正、調(diào)整和改進軟件的難易程度。進行可維護性分析有利于 做出正確的決定,進而采取相應的方法應對客戶的需求,對確實不能或者沒有進行維護的價值的軟件堅決不進行維護,對于可以維護的軟件來說,可維護性分析有助于我們了解軟件情況,從而做出相應的維護措施13.6 (略)13.7 在重構和正向工程之間存在的細微不同是什么?重構是指在統(tǒng)一抽象級別上轉(zhuǎn)換系統(tǒng)的描述形式;正向工程過程應用軟件工程的原理、概念、技術和方法來重新開發(fā)某個現(xiàn)有的應用系統(tǒng)。從概念可以看出,重構是從一個系統(tǒng)環(huán)境轉(zhuǎn)換到另一個系統(tǒng)環(huán)境,而正向工程則是重新開發(fā),從零開始,沒有一定基礎的。13.8 (略)第十四章14.1 何謂軟件項目管理?軟件項目管理與傳
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024音樂素材及視頻素材一次性購買使用合同
- 二零二五年度綠色建筑認證施工承包合同2篇
- 二零二五年度融資租賃抵押借款合同范本3篇
- 2025年星級酒店客房清潔與消毒服務合同3篇
- 二零二五年度新型環(huán)保煤炭開采居間代理合同范本4篇
- 二零二五年飯店服務員工作性質(zhì)與權益保障協(xié)議3篇
- 2025版茅臺酒定制化包裝及銷售服務合同4篇
- 專業(yè)舞臺搭建協(xié)議規(guī)范文本版A版
- 二零二五年度貨車司機勞動合同與運輸合同終止及清算協(xié)議3篇
- 二零二五版生物科技研發(fā)與成果轉(zhuǎn)化合同3篇
- 第二章 運營管理戰(zhàn)略
- 《三本白皮書》全文內(nèi)容及應知應會知識點
- 專題14 思想方法專題:線段與角計算中的思想方法壓軸題四種模型全攻略(解析版)
- 醫(yī)院外來器械及植入物管理制度(4篇)
- 圖像識別領域自適應技術-洞察分析
- 港口與港口工程概論
- 《念珠菌感染的治療》課件
- 新概念英語第二冊考評試卷含答案(第49-56課)
- 商業(yè)倫理與企業(yè)社會責任(山東財經(jīng)大學)智慧樹知到期末考試答案章節(jié)答案2024年山東財經(jīng)大學
- 【奧運會獎牌榜預測建模實證探析12000字(論文)】
- (完整版)譯林版英語詞匯表(四年級下)
評論
0/150
提交評論