軟件工程導論作業
軟件工程導論作業
Chapter1
1.1 什么是軟件危機?它有哪些典型表現?為什么會出現軟件危機?
答: 軟件危機是指在計算機軟件開發和維護過程中所遇到的一系列的嚴重問題。
它的典型表現:1.軟件開發成本高,成本難以控制。2.研究周期長,軟件開發進度難以控制,周期拖得很長。3.正確性難以保證,軟件質量差,可靠性難以保證。4.軟件維護困難,維護人員和維護費用不斷增長。5.軟件發展跟不上硬件的發展和用戶的要求。
它出現的原因一方面是由于軟件生產本身存在著復雜性,另一方面是與軟件開發所使用的方法和技術有關。軟件不同于硬件,它是計算機系統中的邏輯部件而不是物理部件。管理和控制軟件開發工程相當困難,軟件是規模龐大,而且程序復雜性將隨著程序規模的增加而呈指數上升。目前相當多的軟件專業技術人員對軟件開發和維護還有不省糊涂觀念,在實踐過程中或多或少地采用了錯誤的方法和技術,這是使軟件問題發展成為軟件危機的主要原因。
1.2 什么是軟件工程?它有哪些本質特性?怎樣用軟件工程消除軟件危機?
答:軟件工程是將系統化的,規范化的,可度量的方法應用于軟件開發,運行和維護的過程,即將工程化應用于軟件中。
它的本質特性:1.軟件工程關注于大型程序的構造 2.軟件工程的中心課題是控制復雜性 3.軟件經常化 4.開發軟件的效率非常重要 5.和諧地合作是開發軟件的關鍵 6.軟件必須有效地支持它的用戶 7.在軟件工程領域中是由一種文化背景的人替具有另一種文化背景的人創造產品。
基本原理: 1.用分階段的生命周期計劃嚴格管理 2.堅持進行階段評審 3.實行嚴格的產品控制 4.采用現代程序設計的技術 5.結果應能清楚地審查 6.開發小組的人員應該少而精 7.承認不斷改進軟件工程實踐的必要性。
1.3 什么是軟件?它有什么特點?
答:軟件是計算機系統中與硬件相互依存的另一部分,它是包括程序,數據結構及其相關文檔的完整集合。
它的特點是:1.抽象而非具體 2.開發而非制造 3.退化而非磨損 4.定制而非基于構件 5.不可見 6.復雜 7.易改變 8.易復制
1.4 什么是軟件過程?它與軟件工程方法學有何關系?
答:軟件過程是為了開發出高質量的軟件產品所需完成的一系列任務的框架,它規定了完成各項任務的工作步驟。
軟件過程定義了運用技術方法的順序,應該交付的文檔資料,為保證軟件質量和協調軟件變化必須采用的管理措施,以及標志完成了相應開發活動的里程碑。軟件過程是軟件工程方法學的3個重要組成部分之一。軟件工程的基礎是軟件過程。
1.5 什么是軟件生命周期模型?試比較瀑布模型、原型模型、增量模型和螺旋模型的優缺點,說明每種模型的適用范圍。
答:軟件生命周期模型是軟件開發全部過程,活動和任務的結構框架,它能直觀表達軟件開發全過程,明確規定要完成的主要活動,任務和開發策略。也叫軟件開發模型。
瀑布模型 優點:有利于大型軟件開發過程中人員的組織,管理,有利于軟件開發方法和工具的研究,從而提高了大型軟件項目開發的質量和效率。
缺點:1,開發過程一般不能逆轉,否則代價太大 2.實際的項目開發很難嚴格按
照該模型進行 3.客戶往往很難清楚地給出所有的需求,而該模型卻要求如此 4.軟件的實際情況必須到項目開發的后期客戶才能看到,這要求客戶有足夠的耐心。
適用范圍:1.用戶的需求非常清楚全面,且在開發過程中沒有或變化很少 2.開發人員對軟件的應用領域很熟悉 3.用戶的使用環境非常穩定 4.開發工作隊用戶參與的要求很低。
原型模型 優點:1.可以得到比較良好的需求定義,容易適應需求的變化 2.有利于開發與培訓的同步 3.開發費用低,開發周期短且隊用戶更友好。
缺點:1.客戶與開發者對原型的理解不同 2.準確的原型設計比較困難 3.不利于開發人員的創新
適用范圍:1.對所開發的領域比較熟悉而且有快速的原型開發工具 2.項目投標時,可以以原型模型作為軟件的開發模型 3.進行產品移植或升級時,或對已有產品原型進行客戶化工作時,原型模型非常合適。
增量模型 優點:1.采用增量模型的優點是人員分配靈活,剛開始不用投入大量的人力資源
2.如果核心產品很受歡迎,則可增加人力實現下一個增量 3.可先發部分功能給客戶,對客戶起到鎮靜劑的作用。
缺點:1.并行開發構件有可能遇到不能集成的風險,軟件必須具備開放式的體系結構 2.增量模型的靈活性可以使其適應這種變化的能力大于優于瀑布模型和原型模型,但也很容易退化為邊做邊改模型,從而使軟件過程的控制失去整體性。
適用范圍:1.進行已有產品升級或新版本開發,增量模型是非常適合的 2.對完成期限嚴格要求的產品,可以使用增量模型 3.對所開發的領域比較熟悉而且已有原型系統,增量模型也非常適合。
螺旋模型 優點:1.實際上的靈活性,可以再項目的各個階級進行變更 2.以小的分段來構建大型系統,是成本計算變得簡單容易 3.客戶始終參與每個階段的開發,保證了項目不偏離正確方向以及項目的可控性 4.隨著項目推進,客戶始終掌握項目的最新消息,從而是他或她能夠和管理層有效地交互。
缺點:1.采用螺旋模型需要具有相當豐富的風險評估經驗和專門知識,在風險較大的項目開發中,如果未能夠及時標識風險,勢必造成重大損失 2.過多的迭代次數會增加開發成本,延遲提交時間。
適用范圍:只適合于大規模的軟件項目。
1.6 怎么理解軟件工程的概念及其意義?
答:軟件工程是一門將理論和知識應用于實踐的工程,它借鑒了傳統工程的原則和方法,以求高效地開發高質量軟件。它是一種層次化技術。
意義:從歷史上講,軟件工程的作用,是為了克服上個世紀60年代出現的軟件危機,這種危機表現為軟件開發的成本大、進度慢、維護難和質量得不到保障。從當前來講,軟件工程的作用,就是告訴人們怎樣去開發軟件和管理軟件。具體地講,它表現在與軟件開發和管理有關的人員和過程上。
1.7 軟件過程的通用過程框架包含哪兩類活動?
答:一類是框架活動,還有一類是保護性活動。
1.8 描述基于構件開發的思想以及目前的發展情況。
答:基于構件開發強調將被設計的系統分解成功能的或邏輯的構件,構件用定義好的接口進行通信。
它是現在軟件復理論實用化的研究熱點,在構件對象模型的支持下,通過復用已有的構件,軟件開發者可以“即插即用”地快速構造應用軟件,這樣即可以節省時間和經費,提高工作效率,也可以產生更加規范,更加可靠的應用軟件。
1.9 請簡要說明 RUP 的9 個規程(disciplines)及之間關系?
答:RUP的9個規程為:業務建模,需求,分析與設計,實現,測試,部署,配置與變更管理,項目管理以及環境。
對于一個大型項目,RUP九個規程的活動不可或缺,但對于有些項目可能不需要經過所有九個規程,在項目開發時需要對這些規程涉及的活動做具體的裁剪,以適應具體項目的開發需要。
1.10 說明面向切面編程的特點,有什么優勢?
答:該范型以一種稱為切面的語言構造為基礎,切面是一種新的模塊化機制,用來描述分散在對象、類或函數中分離出來可以大大增強程序的模塊性。
優勢:他把特定領域問題的代碼從業務邏輯中獨立出來,業務邏輯的代碼中不再含有針對特定領域問題代碼的調用,業務邏輯同特定領域問題的關系通過切面來進行封裝,維護。 優勢:面向切面編程的特點是針對業務處理過程中的切面提取,所面對的是處理過程中的某個步驟或階段,以獲得邏輯過程中各部分之間低耦合性的隔離效果,降低了耦合性。
1.11 模型驅動工程中 MDA 的基本思想是什么?
答:MDA的基本思想是系統的功能性是用合適的規約語言以平臺無關的模型的方式定義,然后為實際的實現翻譯到一個或多個平臺相關的模型上。
Chapter2
2.1 描述面向對象的基本概念和思想。
答:面向對象是一種以對象為基礎,以事件或消息來驅動對象執行處理和程序設計技術。 面向對象的基本思想是認為客觀實體和實體之間的聯系構成了現實世界的所有問題,而每
一個實體都可以抽象為對象。
2.2 面向對象分析設計的基本思路和過程是怎樣的?
答:分析過程主要包括理解、表達和驗證。設計是把分析階段得到的需求轉變成符合成本和質量要求的、抽象的系統實現方案的過程。
過程:識別系統的用例和角色,進行系統分析并抽象出類,設計系統并設計系統中的類及其行為。
2.3 面向對象程序設計中的概念主要包括哪些?分別闡述其主要思想。
答:對象:封裝了數據和操作這些數據的代碼的邏輯實體。
類:具有相同類型的對象的抽象。
封裝:保證軟件部分具有優良的模塊性的基礎。
繼承:讓某個類型對象獲得另一個類型的對象特征。
多態:使不同內部結構的對象可以共享相同的外部接口,減少代碼復雜度。
動態綁定:多態實現的具體形式,將一個過程調用與相應代碼鏈接起來的行為。 消息傳遞:使得對現實世界的描述更容易。
方法:定義一個類可以做的,但不一定去做的事。
2.4 描述 UML 的主要概念和歷史。
答:UML是統一建模語言,用來對軟件密集系統進行可視化建模的一種語言。UML為面向對象開發系統的產品進行說明、可視化、和編制文檔的一種標準語言。
歷史:Rumbaugh和Booch將Booch93和OMT-2統一起來,發布了UM0.8;后經過Booch,Rumbaugh和Jacobson的共同努力,發布了UML0.9和UML0.91,并將UM重命名為UML。97年,Rational組織成立了UML合作者聯盟,以完善、加強和促進UML的定義工作。2000年啟動了UML2.0標準的制定工作。
2.5 RUP 是什么?應用RUP 對軟件開發有什么意義?
答:RUP(Rational Unified Process)是統一軟件開發過程,是一個面向對象且基于網絡的程序開發方法論。
應用RUP為軟件開發提供了一個模版,使得軟件開發過程規范化,統一化。
Chapter3
3.1 為什么要進行業務建模?業務建模適用什么場合的軟件項目開發?
答:進行業務建模的原因:業務人員、IT技術的業務知識、IT技術知識彼此之間存在著較大的差異,而規模較大的軟件開發項目是不太可能讓所有參加項目的IT技術人員都先熟悉
業務知識而再進行開發的,所以需要通過“業務建模”將“業務需求”準確地轉換為IT技術人員所熟悉的“軟件需求”。
適用場合:規模較大的軟件項目開發。
3.2 業務建模可以分哪些工作流進行?
答:評估業務狀態、描述當前業務、定義業務、探索流程自動化、開發領域模型。
3.3 什么是領域模型?與業務模型的關系是什么?
答:領域模型:領域模型是描述業務用例實現的對象模型。它是對業務角色和業務實體之間應該如何聯系和協作以執行業務的一種抽象。領域模型從業務角色內部的觀點定義了業務用例。該模型為產生預期效果確定了業務人員以及他們處理和使用的對象(“業務類和對象”)之間應該具有的靜態和動態關系。它注重業務中承擔的角色及其當前職責。這些模型類的對象組合在一起可以執行所有的業務用例。
關系:開發領域模型是一個備選活動,領域模型是業務分析模型中獨立的一部分,注重于說明對于業務領域很重要的概念、產品、可交付成果和事件。這樣一個模型僅描述業務中的重要信息,并不包括人員承擔的職責。
3.4 什么是系統上下文?明確目標系統的上下文有什么意義?
答:系統上下文:指的是目標系統、與之交互的用戶和外部系統。
意義:業務建模作為軟件需求的前一階段,了解目標系統的上下文是很有必要的,便于確定目標組織和業務范圍。
3.5 什么是業務涉眾?業務涉眾可能來自哪些方面?
答:業務涉眾:所有跟目標業務有利害關系的人。
方面:可能來自目標組織內部及目標組織外部且跟目標組織有關系的人和組織。
3.6 什么是業務愿景?怎么理解業務愿景的重要性?
答:業務愿景:定義業務建模工作所針對的一組目標。
重要性:要了解組織的業務過程,對業務進行建模,首先必須理解組織的共同愿景,業務建模時期的重要任務就是確定項目涉眾的共同愿景,而了解最有影響力的涉眾的愿望和目標是非常重要的環節。所以業務愿景對整個業務建模過程來說是十分關鍵和重要的。
3.7 業務建模的作用是什么?哪些人和組織是潛在的業務執行者?
答:作用:
(1)了解目標組織(將要在其中部署系統的組織)的結構和機制;
(2)了解目標組織中當前存在的問題并確定潛在改進的可能性;
(3)確保客戶、最終用戶、開發人員和其他各方就目標組織達成共識;
(4)導出支持目標組織所需的系統需求;
(5)了解要部署的軟件系統將如何融入組織。
潛在的業務執行者:客戶、合作伙伴、供應商、權威機構(法律、法規等制訂機構)、子公司、所有者和投資者、業務以外的信息系統等。
3.8 結構化業務用例的三種關系是什么?
答:三種關系:包含關系、擴展關系、泛化關系。
3.9 業務用例的包含與擴展關系、包含與泛化的區別是什么?
答:包含與泛化的區別:(1)對于用例泛化關系,子用例的執行取決于父用例(重用部分)的結構和行為,而在包含關系中,基本用例的執行只取決于包含用例(重用部分)所執行的功能的結果。(2)在泛化關系中,子用例的用途和結構是相似的,而在包含關系中,重用同一個包含用例的基本用例可能有完全不同的用途,但需求執行相同的功能。
包含與擴展的區別:(1)包含關系:如果基本用例的某個部分代表一個功能,而業務用例只依賴于本功能的結果,而不是產生結果的方法,那么可以將這部分分離出來,形成一個附加用例。使用包含關系,將附加部分明確包含于基本用例中。包含關系將基本用例和包含用例連接起來。
(2)擴展關系:如果基本用例的一部分是可選的,或對于理解該用例的主要目的來說不是必需的,那么可以將這部分分離出來,形成一個附加用例,以簡化基本用例的結構。利用擴展關系,將附加部分隱含地包含于基本用例中。擴展關系將擴展用例與基本用例連接起來。
3.10 業務分析模型的作用是什么?與業務用例模型的之間是什么關系?
答:作用:業務分析模型描述通過與業務系統、業務工作者和業務實體交互來實現業務用例。它充當了為了執行業務用例而所需業務系統、業務工作者和業務實體之間的相關和協作方式的.抽象。它還定義了在執行業務用例時由業務執行者調用的外部業務服務。
關系:業務用例模型是從與客戶和業務流程對應的業務執行者和業務用例的角度,對業務進行描述。業務用例模型包括工作流程說明,此說明確定完成了那些工作。所以業務用例模型描述在業務執行者和業務之間發生了什么,對于業務結構或如何實現業務用例不作任何假設。而業務分析模型就是用于描述如何執行業務用例,并具體定義業務提供的服務,內部業務工作者及其使用的信息,將它們的結構化組織描述為獨立的單元,定義業務工作者如何通過交戶來實現業務用例中所描述的行為。
3.11
(c)
2. 以醫院為研究對象,請描述醫生、病歷的性質分別是( )
(a) business actor、business worker
(b) business worker、business actor
(c) business actor、business entity
(d) business worker、business entity
3.12 綜合案例分析-餐廳點菜業務分析
某餐廳的點菜服務流程與規范如下:
1.遞上菜單
(1)客人入座后,服務員詢問客人需要什么茶水。準備好茶水后,按“女士優先,先
賓后主”的原則從右邊為客人斟上茶水。
(2)將菜單打開第一頁,按照“女士優先”原則,用雙手從客人右側將菜單送至客人 手中,然后站在客人斜后方能觀察客人面部表情的地方,上身微躬。
2.推薦介紹酒店菜品
(1)在客人點菜前,服務員應留有時間讓客人翻看菜單。
(2)在客人翻看菜單時,應及時向客人簡單介紹菜單上的菜,回答客人的詢問。
(3)向客人介紹廚師長今日特別推薦的菜品、其他的特色菜、暢銷菜和高檔菜等菜品, 并介紹其樣式、味道、溫度和特點。
3.接受點菜
(1)服務員先在點菜單上記下日期、本人姓名及臺號、就餐人數等。
(2)客人點菜時,應注視客人,聽清客人點的菜名,適時幫助客人選擇菜品和主動推 介菜品,準確地記錄菜名。
(3)對于特殊菜品,應介紹其特殊之處,并問清客人所需火候、配料及調料等。
(4)若客人用餐時間較緊,點的菜需時間較長,則應及時向客人征求意見;若有客人 點相同的菜式,如湯和羹或兩個酸甜味型的菜時,應有禮貌地問客人是否需要更換菜式。
(5)若客人有特殊要求,應在點菜單上清楚注明,并告知傳菜服務員。
4.復述點菜內容
(1)客人點菜完畢后,服務員應清楚地重復一遍所點菜品內容,并請客人確認。
(2)復述完畢后,在點菜單的右上角寫明當時的時間,以便查詢。
(3)收回菜單并向客人致謝,同時請客人稍等,說明大致的等候時間。
5.分送點菜單
(1)服務員將點菜單的第一聯送至收銀處。
(2)將點菜單的第二聯送至廚房。
(3)將第三聯給客戶,第四聯交給傳菜員、值臺服務員留底備查。
根據案例的描述,請你完成下列任務:
1. 分析餐廳的點菜業務,建立點菜業務模型。
這項業務的業務涉眾:外部涉眾:客人,
內部涉眾:服務員,收銀處,廚房,值臺服務員
分析點菜業務模型:
業務執行者為:客人
業務用例是:入座,推薦菜品,點菜,確認內容,分送菜單,上菜
2. 用活動圖描述客人點菜的活動。
3. 分析點菜業務模型,找出有哪些業務工作者和業務實體,并用交互圖來說明之間的通信和交互關系。
業務工作者為:服務員,收銀處,廚房,值臺服務員
業務實體為:菜單,點菜單
Chapter4
4.1 需求的類別有哪些?
答:需求可分為功能性需求和非功能性需求。
功能性需求規定了系統無需考慮物理約束而必須能夠執行的動作,描述支持用戶目標、任務或活動的系統行為(功能或服務)。
非功能性需求是功能性需求之外的需求,包含質量和約束,它們僅僅說明系統或系統環境的屬性。
4.2 怎么理解文中 Fred Brooks 關于需求的那段話?
構建軟件系統最難的部分是確定要構建什么(即系統需求)。相比其他工作,如果這個工作做錯,會嚴重影響將產生的系統,也更難在以后矯正。
答:需求工作對于整個軟件系統來說是非常重要的,它是實現和測試的先啟階段,需求建模解釋如何理清涉眾的請求及如何把這些請求轉化為一組需求工作產品,確定要建系統的范圍,提供系統必須做的詳細要求。此階段是后續工作以及整個系統的基礎和關鍵,一旦這個階段出現問題,將會直接影響到后續工作的正常順利進行,而如果想要在以后改,代價是非常大的,并且也難糾正。
4.3 系統用例模型可以描述什么方面的需求?補充規約主要補充哪方面的需求?
答:系統用例模型可以描述設計軟件系統方面的需求,參與者與軟件系統的交互,在系統用例說明中書寫足夠詳細的事件流。
補充歸約主要補充那些無法在用例中記錄的需求。包括:捕捉無用例歸約的功能性需求,捕捉系統資量,捕捉約束,捕捉符合性需求,捕捉文檔需求。
4.4 什么是系統執行者?如何尋找潛在的系統執行者?
答:系統執行者:是指與目標系統交換數據的任何對象,是在系統之外,透過系統邊界與系統進行有意義交互的任何事物。執行者可以是用戶、外部硬件或其它系統。
尋找潛在的系統執行者:首先可以從業務模型中去查找,那些業務執行者和業務工作者是潛在的系統執行者。如果沒有做業務建模,那可以回答以下問題:哪些用戶組需要系統幫助來執行它們的任務?執行系統最明顯的主要功能需要哪些用戶組?要求哪些用戶組執行次要功能,如系統維護和管理?哪些外部硬件或軟件系統會與新系統交互嗎?是否有事情在預定的時間自動發生?
滿足一個或多個上面這些范疇的任何個人、小組或事物有可能就是執行者。
4.5 如何理解系統執行者與業務執行者、業務工作者的關系?
答:業務執行者是指某人或某物與業務進行交互時所擔任的角色,它是指在業務之外和業務交互的人、組織或事物。
業務工作者代表在業務中進行操作的人、軟件或硬件的抽象。它代表業務中的一個或一組角色。
系統執行者:是指與目標系統交換數據的任何對象,是在系統之外,透過系統邊界與系統進行有意義交互的任何事物。執行者可以是用戶、外部硬件或其它系統。
關系:系統執行者是針對軟件系統來說明的,而業務執行者和業務工作者是針對業務來說明的,系統執行者和業務執行者含義相似,只是所在的描述范疇不一樣。
4.6 請分析用例中的包含關系和擴展關系的相似與區別?
答:相似:都是如果用例包含的一段行為片段可以用于其他用例,則將這段行為片段歸到“包含用例”或“擴展用例”中,形成一個新的用例,原始用例就成為基本用例,對“包含用例”和“擴展用例”分別有包含關系和擴展關系。
區別:(1)擴展用例是可選的,而包含用例不是可選的;(2)基本用例沒有擴展用例是可以完成的,但沒有包含用例則不能完成;(3)擴展用例的執行是有條件的,而包含用例沒有;(4)擴展用例會改變基本用例的行為,而包含用例不會。
4.7 簡單說明把用例組織到包中有什么好處。
答:用例包是用例、執行者、關系、圖和其他包的集合,可以通過將用例模型分成更小的部分來結構化用例模型。這樣可以使得具有大量元素的用例模型中的用例結構化,同一包中的用例彼此之間都有某種關系,更加清楚明了,便于以后模型的分析和使用。
4.8 用例詳細描述中有哪三種事件流,分別表示什么場景?
答:三種事件流:主事件流、分支事件流和異常事件流。
主事件流:在描述正常過程時列出執行者和系統之間相互交互或對話的動作序列。當這種對話結束時,執行者也達到了預期的目的。
分支事件流:也可促進成功地完成任務,但它們代表了任務的細節或用于完成任務的途徑的變化部分。
異常事件流:不符合用例流正常或基本行為,引起任務不能順利完成。
4.9 什么是軟件需求規約(SRS)?
答:軟件需求規約是分析任務的最終產物,通過建立完整的信息描述、詳細的功能和行為描述、性能需求和設計約束的說明、合適的驗收標準,給出對目標軟件的各種需求。
4.10 如何理解界面原型在需求建模中作用?
答:可以處理模糊需求,開發者和用戶可充分通信,降低開發風險。
靜態界面原型:供分析人員與用戶進行進一步交流和溝通,通過這種可視化方法,使雙方逐步就明確系統需求達成共識。
交互式界面原型:便于用戶可以操作,展示實際系統效果。
4.11 選擇題
1. 如圖4.11-1所示. A1 、A2 和A3 是什么? (單選題)( C)
(a) role
(b) Actress
(c) Actor
(d) User
2. 如圖4.11-1中,下面哪個語句是正確的? (多選題) ( BCD) (a) A3 可以使用UC4 與系統交互。
(b) Al 可以使用UCl 和UC4 與系統交互。 (c) A3, Al 與A2 不同。
(d) UC3 是沒有步驟的抽象用例。
3. 如圖4.11-1 所示,下面哪個語句是正確的? (多選題)(CD ) (a) UC5 是UC4 的補充部分。 (b) UC4 是UC5 的可選部分。 (c) UC1 是沒有用的。
(d) UC2 是UC4 的可選部分。 (e) UC4 是UC2 的補充部分。
4.12 綜合案例分析-餐廳智能移動終端無線點菜系統需求
根據第 3 章的練習3.11 綜合案例分析的業務描述,來分析點餐系統的需求。
現在該餐廳為了提高管理效率,避免在點菜過程中出現掉單、飛單,錯單、舞弊等現象,計劃采用智能移動終端無線點菜系統。 無線點菜系統的要求: 1. 即時點菜
服務員隨時隨地地使用智能掌上電腦系統,為顧客點菜、加菜,系統自動將數據傳到后臺和分布在廚房與前臺的打印機上。打印機立刻打印所點的菜單。 2. 無需布線
系統前臺使用無線網絡與掌上電腦技術,使前臺使用者可以在營業大廳內隨意走動,自由的使用系統為顧客服務,無需在大廳中布置任何網絡線路,從而避免影響餐廳的整體環境。 3 操作簡單
系統采用 B/S 結構,前臺使用智能移動終端如智能手機、平板電腦做客戶端,所有的操作都是筆觸式和手寫輸入,操作要方便,適宜于任何服務人員http://http://salifelink.com/news/55840068E518E83F.html使用。 4. 超長傳送
傳送距離可達 100 米,室外傳送距離可送300 米。 根據案例的描述,請你完成下列任務:
1. 建立無線點菜系統的用例模型(找出所有的系統 Actor 和Use Case);
用例模型
系統Actor:服務員、客戶、經理
Use case:點菜服務、自助點菜、統計
2. 對用例進行詳細描述,包括前置條件、后置條件,以及各事件流,并用泳道圖畫出用例對應的事件流。 前置條件:
服務員有掌上電腦系統,廚房與前臺有打印機,在傳輸距離之內 后置條件:
打印機打印所點菜單 事件流: 主事件流: 1.顧客點菜;
2.服務員用掌上電腦及菜單; 3.廚房和前臺打印機打印菜單 分支事件流: 無
異常事件流:
步驟2后步驟3未接收,無法打印,返回步驟
2
3).打印菜單用例描述: 用例名稱:打印菜單
用例描述:打印點菜內容 參與者 :打印機 前置條件:點菜完成
后置條件:打印機打印菜單給后臺,廚房和前臺 主事件流:1.系統發送點菜單至打印機
2.打印機接收菜單 3.打印機打印菜單 分支事件流:無 異常事件流:無 泳道圖:
Chapter5
5.1 如何理解分析與設計的聯系?
答:“分析”是指“做什么”,強調對問題的調研而不是如何確定解決方案,重點集中在需求和應用領域上;而“設計”指“怎么做”,強調的是問題的邏輯解決方案,即系統怎樣才能滿足需求,重點轉移了要產生軟件的結構上。但由于分析與設計是把用戶需求轉化為實現的橋梁,分析和設計自始至終可以用相同的技術和類似的表示方法,它們之間的界限很難劃清,且沒有太多意義。
5.2 分析設計包括哪些工作流程?
答:分析和設計過程是一個不斷迭代優化的過程。
包括:執行體系結構合成;定義候選體系結構;優化體系結構;分析行為;設計構件;設計數據庫;服務識別;服務規范。
5.3 分析建模的元素分哪幾類?具體是什么? 答:分析建模的元素分為四大類,分別是: (1)基于場景元素:
這類元素包括:用例文本、用例圖、活動圖和泳道圖等; (2)面向流的元素:
這類元素包括數據流圖、控制流圖、處理敘述等; (3)基于類的元素:
這類元素包括類圖、分析包、CRC模型、通信圖等; (4)行為的元素:
這類元素包括狀態圖、順序圖等。
5.4 分析模型的靜態模型的用途是什么?靜態模型的元素有哪些?
答:用途:通過分析,可以將業務需求模型和系統需求模型轉化為系統可以處理的對象模型,并給出對象的基本屬性和對象間相互關系。
分析模型中靜態模型主要的元素是基于類的元素,包括: 分析包:模型中的包,表示層次結構。 類:模型中的類,由包所擁有。 關系:模型中的關系,由包所擁有。
圖:模型中的類圖、協作(通信)圖,由包所擁有。
5.5 動態模型的類被分為哪三類?分別在系統中承擔什么職責? 答:邊界類、控制類和實體類。
邊界類:是用來對系統環境及其內部工作之間的交互建模的類。這樣的交互涉及轉換和轉移事件,并注釋系統表示中的更改(例如界面)。
控制類:是用于對特定于一個或一些用例的控制行為建模的類。 實體類:是用來對必須存儲的信息及關聯行為建模的類。
5.6 按照設計模型的不同層次和功能,設計元素可以分哪些方面?
答:(1)體系結構元素;(2)構件級元素;(3)接口/界面元素:用戶界面、構件接口、系統接口;(4)數據元素:數據庫設計、數據結構設計;(5)部署級元素。
5.7 軟件模式有哪三個層次?分別說明之。
答:一般地,軟件模式可劃分為三個層次:體系結構模式,設計模式和代碼模式。
體系結構模式:描述軟件系統里的基本的結構組織或綱要。體系結構模式提供一些事先定義好的子系統,指定它們的責任,并給出把它們組織在一起的法則和指南。
設計模型:提供一種提煉子系統或軟件系統中的構件或者兩者之間關系的綱要設計。設計模型描述普遍存在的在相互通訊的構件中重復出現的結構,這種結構解決在一定的背景中的具有一般性的設計問題。
代碼模型:也稱“成例”、實現模式。是較低層次的模式,并與編程語言密切相關。代碼模型描述怎樣利用一個特定的編程語言的特點來實現一個構件的某些特定的方面或關系。
5.8 什么是軟件體系結構?簡述軟件體系結構的設計重要性。
答:軟件體系結構:是具有一定形式的結構化元素,即構件的集合,包括處理構件、數據構件和連接構件。處理構件負責對數據進行加工,數據構件是被加工的信息,連接構件把體系結構的不同部分組組合連接起來。這一定義注重區分處理構件、數據構件和連接構件,這一方法在其他的定義和方法中基本上得到保持。
重要性:軟件體系結構設計是高階層的設計,定義了包(子系統),包括包之間的依賴關系和主要的通信機制。自然清晰和簡單的結構是目標,避免幾乎沒有依賴或雙向依賴。
5.9 試說明軟件體系結構的演變過程。
答:(1)單機系統:是指只需裝在一臺電腦上,同時只能一個用戶使用的系統,沒有服務器概念,很多早期的軟件都是單機系統,與分布式系統區別。
(2)客戶機/服務器(兩層)結構:由服務器提供應用(數據)服務,多臺客戶機進行連接。
(3)瀏覽器/服務器(B/S)結構:在當前Internet/Intranet領域,“瀏覽器/服務器”結構是非常流行的客戶機/服務器結構。這種結構最大的優點是:客戶機統一采用瀏覽器,這不僅讓用戶使用方便,而且使得客戶機不存在安裝維護問題。
(4)三層結構:三層結構的客戶機/服務器模型是一種先進的協同應用程序開發模型,不是物理上,而是邏輯上將客戶機/服務器系統中各種各樣的部件劃分為三“層”服務,它們共同組成一個應用程序,這三層服務包括:數據訪問層、業務邏輯層和表示層。
5.10 如何理解體系結構風格和模式的本質?
答:體系結構風格:定義了結構組織模式的系統族,用來表達一組協作的約束,使得對公共約束的特征進行溝通變得更加容易,被用作一種進行抽象的方法,而不是代表一種個性化的設計。
體系結構模式:是對某類問題域給出的一套軟件結構的解決方案,描述了軟件系統基本的結構化組織方案,是處理特定問題的高效、成熟的模板。
5.11 什么是軟件框架?與模式的區別是什么?
答:軟件框架:軟件開發過程中提取特定領域軟件的共性部分形成的體系結構,不同領域的軟件項目有著不同的框架模型。
區別:模式提供一種思想方法的指導,應用模式的指導,可以幫助設計人員做出一個優良的設計方案,達到事半功倍的效果。但模式不體現為程序,如MVC是一種體系結構的模式,對于同一軟件體系結構,可以通過多種框架來實現。如Struts是實現MVC模式的著名框架,但不是唯一的。
5.12 RUP 的4+1 視圖分別是什么? 答:概括而言,RUP的4+1視圖是: (1)邏輯視圖:設計的對象模型。
(2)進程視圖:捕捉設計的并發和同步特征。
(3)實現視圖:描述了在開發環境中軟件的靜態組織結構。
(4)部署視圖:描述了軟件到硬件的映射,反映了分布式特征。
(5)用例視圖:該視圖是其他視圖的冗余(因此“+1”)。它包含用例和場景。
5.13 什么是設計模式?
答:設計模式:是一套被反復使用、多數人知曉的、經過分類編目的、代碼設計經驗的總結。使用設計模式是為了可重用代碼、讓代碼更容易被他人理解、保證代碼可靠性。 毫無疑問,設計模式于己于他人于系統都是多贏的,設計模式使代碼編制真正工程化,設計模式是軟件工程的基石,如同大廈的一塊塊磚石一樣。
5.14 簡要說明類的詳細設計分哪幾步來實現?
答:(1)使用設計模式和機制:使用適合設計的類或功能、符合項目設計指南的設計模式和機制。
(2)創建初始設計類:為指定為此任務輸入的分析類創建一個或多個初始設計類,并指定跟蹤依賴關系。包括設計邊界類、設計實體類和設計控制類。
(3)定義屬性:類的屬性為類實例提供信息存儲,并經常用于代表類實例的狀態。類本身保持的任何信息都是通過其屬性完成的。
(4)確定持久類:需要在永久介質上存儲其狀態的類被稱為持久類。
(5)定義操作:類的操作是類的行為特征或動態特征,表示類提供的服務。 (6)定義方法:方法制定操作的實現。
(7)定義狀態:對于一些操作,操作的行為取決于接受者對象所處的狀態。
5.15 什么是實體類與持久類?說說兩者之間區別與聯系。
答:實體類:在分析期間,代表被操縱的信息單元。它們往往是被動的、持久的,并且可能被確定并與持久性分析機制相關聯。
持久類:需要在永久介質上存儲其狀態的類。
區別和聯系:持久類是針對于hibernate對數據庫的映射來說的,持久類=實體類+xml或注解配置;而實體類就是一個javabean類,有屬性,get、set方法,以及一些簡單處理的方法。
5.16 開發物理數據庫設計的詳細步驟有哪些?
答:(1)定義域;(2)創建初始物理數據庫設計元素;(3)定義引用表;(4)創建主鍵和唯一性約束;(5)定義數據和參照完整性實現規則;(6)將數據庫設計反向規范化來為性能進行優化;(7)優化數據訪問;(8)定義存儲器特征;(9)設計存儲過程來將類行為分發給數據庫。
5.17 進行界面設計時分析用戶的特征有什么作用?
答:描述某些(人類)用戶的特征,這些用戶將與系統交互來執行當前迭代中考慮的需求。要重點描述主要用戶,因為交互的大部分涉及這些用戶。該信息對于下面的后續步驟很重
要。
與系統分析人員協作,確定是否需要對用戶(主要的執行者)描述做出更改,來反映特征描述。
5.18 選擇題
1. 如圖5.18-1 所示.A 、B 和C 是什么對象? (單選題)(D) (a) A 是實體.B 是控制.C 是邊界 (b) A 是邊界.B 是實體.C 是控制 (c) A 是實體,B 是邊界, C 是控制 (d) A 是控制,B 是實體.C 是邊界 (e) A 是邊界.B 是控制,C 是實體 (f) A 是控制,B 是邊界.C 是實體
2. 在UML圖中,哪個圖用于顯示在對象之間傳送的消息? (多選題)( CE) (a) 活動圖 (b) 對象圖 (c) 通信圖 (d) 狀態機圖 (e) 順序圖 (f) 部署圖
3. 下面不是設計模型相關的?(單選題)( D) (a)architecture (b) data
(c) interfaces (d) project scope
5.19 綜合案例分析-餐廳PDA 無線點菜系統分析與設計
根據第 4 章餐廳PDA 無線點菜系統的需求,請分析設計相關系統。包括 1. 找出主要的概念實體,畫出實體類圖。
2. 畫出系統分析動態模型中的順序圖(要體現邊界類、控制類和實體類之間通信內容)。 3. 從上面的順序圖中解析出實體類的操作,畫出初步的設計類圖。 4. 選擇B/S結構,為系統設計相應的界面。 5. 設計相應的數據庫表結構
答:1.主要的概念實體:客人,點菜單,點菜記錄,打印機,服務員,菜品分類
實體類圖:
2.
3.實體類操作:1)客人: 輸入已點菜品()
2)點菜記錄:記錄已點菜品();確認點菜記錄();發送點菜記錄() 3)打印機:打印點菜記錄()
類圖:
4.界面:
5.數據庫表結構:
2013.01.05
【軟件工程導論作業】相關文章:
軟件工程導論課程教學改革的探討07-29
軟件工程導論課程中同伴教學法的應用的論文10-10
軟件工程導論課程中同伴教學法的應用論文06-19
《現代教師學導論》形成性考核冊作業3答案01-13
《軟件工程導論》期末考試試題和答案206-28
電氣導論論文09-05
旅游美育導論01-20
護理教育導論07-06
物聯網工程導論01-15