軟件工程Computer Science 上

上傳人:e****s 文檔編號:249101244 上傳時間:2024-10-27 格式:PPT 頁數(shù):118 大?。?71.50KB
收藏 版權(quán)申訴 舉報 下載
軟件工程Computer Science 上_第1頁
第1頁 / 共118頁
軟件工程Computer Science 上_第2頁
第2頁 / 共118頁
軟件工程Computer Science 上_第3頁
第3頁 / 共118頁

下載文檔到電腦,查找使用更方便

20 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《軟件工程Computer Science 上》由會員分享,可在線閱讀,更多相關(guān)《軟件工程Computer Science 上(118頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、Click to edit Master title style,,Click to edit Master text styles,,Second level,,Third level,,Fourth level,,Fifth level,,,*,Computer Science 306 1/15/03,Bill Bond,,Class Communication,Email your name and email address to,,Normally will post notes before class,,Assignments got to,,Web page should be

2、 in following location: ://web.umr.edu/~umreec/web-courses/,,Software Crisis,Programs don’t reflect customer desires,,Schedule and cost estimates are often grossly inaccurate,,“Productivity〞 of software people has not kept pace with the demand for their services,,Software complexity increases,,Q

3、uality of software is sometimes less than adequate,,Difficult to maintain existing programs,,The Problem,Building computer solution is hard,,Understand problem,,Design solution,,Implement solution,,,Complexity is the problem,,Lots to do,,Lots to keep track of,,Software Engineering,Managing complexit

4、y by imposing discipline,,Abstraction - focus only on essential details, ignore others (for now),,Decomposition - break into manageable pieces,,,Analysis/Design methods and Tools support these ideas,,Large Projects,Require Teams,,Key elements,,Communication - has cost,,Artifacts - support communicat

5、ion,,Artifacts,Which should be produced?,,“Discovery〞 value,,Which should be maintained?,,Maintenance value,,,Recognize cost of producing artifacts,,Software Engineering,Book definition – The establishment and use of sound engineering principles in order to obtain economical software that is reliabl

6、e and works efficiently on real machines,,,Result,Comprehensive methods – “how to〞,,Process – context in which technical methods applied, deliverables produced,,Better tools,,More powerful building blocks,,Better quality assurance,,Communication,,Three Generic Phases,Definition phase,,What,,Informat

7、ion to be processed,,Function/Performance desired,,System Engineering,,Software Project Planning,,Requirements Analysis,,,Three Generic Phases, cont,Development phase – how,,Software architecture,,Implementation,,Testing,,Three Generic Phases, cont,Maintenance phase – change,,Correction – defect cor

8、rection,,Adaptation – supports new environment,,Enhancement,,Prevention – changes to allow correction, adaptation, enhancement,,Course Description,All aspects of software engineering,,Project management,,Requirements,,Analysis,,Design,,Implementation,,Testing,,More,,,Introduction to Object-Oriented

9、Analysis and Design,Bill Bond,,10/16/02,,Schedule,10/16 - Background,,10/23 - Exam,,10/30 - Analyze - Use Cases, Domain Model,,11/6 - Design - Collaboration / Design diagrams,,11/13 - Construct - Code,,11/20 - Complete, Begin examples,,11/27 - No class,,12/4 - Examples,,12/11 - Project due, UML Odds

10、 and Ends,,12/18 - Final Exam,,Chapter 1 - Goals,Describe Process,,Repeatable, predictable results,,Requirements development,,Use Cases,,Conceptual Model,,Design Model,,Sequence Diagrams,,Produce code,,Goals,Learn basic set of UML,,Unified Modeling Language,,Capture Analysis/Design,,Communicate with

11、 other developers,,Apply “good〞 design principles,,Patterns (good design solutions),,Work examples,,Part of Engineering Process,Estimating,,Planning/Scheduling,,Configuration Management,,Change Control,,Peer Reviews,,Testing,,,Unified Modeling Language,Industry standard,,Rational proposal,,Booch - B

12、ooch diagrams,,Model diagrams,,Rumbaugh - Object Modeling Technique,,Model diagrams,,Jacobson - Objectory,,Process,,Unified Modeling Language,Set of Diagrams,,Different views of a system,,Concentrate on a,subset,,Use cases,,Sequence / Collaboration diagrams,,Dynamic (Execution) view,,Conceptual / De

13、sign model,,Static view - can produce code,,,,,Unified Modeling Language,Does not define an approach,,But we will - Unified Process,,,Artifacts,What artifacts should be produced?,,What artifacts should be peer reviewed?,,What artifacts should be maintained?,,Design evolves over time,,Artifacts,Repre

14、sent cost,,Improved process repeatability,,Improved design / quality through self-discovery,,Improved design / quality through peer review,,What Does Customer Want?,Reasonable cost,,Delivered on schedule,,Meets requirements,,High quality,,Analysis / Design,Analysis (what) - Investigation of the pro

15、blem domain, rather than how the solution is defined,,Design (how) - Logical solution, how system fulfills the requirements,,Analysis / Design,Analysis,Design,What,,Requirements,,Investigation of Domain,How,,Logical solution,,Function-Oriented Approach,Decomposition is primary strategy,,Construct a

16、“control〞 hierarchy,Control,I/O,Processing,,OOA /OOD,Consider problem domain /solution from the perspective of objects,,OOA - Find and describe domain (problem space) objects,,OOD - Define logical software objects that will be implemented in an Object-Oriented Programming Language,,Approach,Assign r

17、esponsibilities to components,,Important question (should be able to answer) - What is this component responsible for? What does it do (exactly)?,,Find suitable objects / abstractions,,Domain (Conceptual) model -> Representation -> Code,,Is An Object-Oriented Language Required?,No,,Business Example,

18、Textual narrative description of business processes,,External actors - cause business to process data,,Results produced by interaction between people,,Expectations - what should be the outcome?,,Use case,,Business Example,People roles,,What “categories〞 of people participate in the domain,,Responsib

19、ilities,,Conceptual (domain) model,,Interactions,,How collaboration occurs to achieve overall goals,,Collaboration (sequence) diagrams,,,Chapter 2 - Macro Process,Development Process - Organize software activities for creation, delivery, and maintenance,,Macro level,,Plan and Elaborate,,Build,,Deplo

20、y,,Plan and Elaborate,Plan - schedule, resources, budget,,Preliminary investigation report,,Requirements investigation,,Glossary,,Prototype,,Use Cases - text,,Use Case Diagrams,,Draft Conceptual Model,,Unified Process,Book describes a simplified version of the Rational Unified Process,,A “typical〞 O

21、OA / OOD process,,Iterative Development,Successive refinement through multiple cycles (adding more functions) of,,Analysis,,Design,,Implementation,,Test,,Waterfall - a,single,cycle,,Iterative Development,Each iteration produces an executable but incomplete system,,System may not be eligible for prod

22、uction deployment for many iterations,,Iteration output is not a “throw-away〞 prototype, it is a production-grade subset of the final system,,Benefits,Early rather than late mitigation of high risks (technical, requirements, usability, etc.),,Early visible progress,,Early user feedback,,Managed comp

23、lexity,,Development feedback can be used to update the process,,Waterfall,,Iteration,,Iterations,Time Boxing - Fixed time iteration cycle,,Choose iteration requirements carefully,,Organized by Use Cases,,Each iteration implements a set of use cases,,,,Advantages,,Iterations,,Work Activities,,UP Best

24、 Practices,Tackle high-risk, high-value issues early,,Continuously engage users,,Build cohesive, core architecture early,,Continuously verify quality through test,,Model software visually with UML,,Carefully manage requirements,,Practice change request and configuration management,,Chapter 4 - Incep

25、tion,Envision the product scope, vision, and business case,,The main problem: Do the stakeholders have basic agreement on the vision of the project, and is it worth investing in serious investigation?,,Chapter 5 - Requirements,Requirements are capabilities and conditions to which the system must con

26、form,,,UP Requirements,Manage requirements - define and stabilize the requirements - in the context of inevitably,changing,and unclear stakeholder’s wishes, a systematic approach to,finding,, documenting, organizing and tracking the changing requirments of a system,,“Challenged〞 Projects,,FURPS+,Fun

27、ctional - features, capabilities, security,,Usability - human factors, help, documentation,,Reliability - frequency of failure recoverability, predictability,,Performance - response times, throughput, accuracy, availability, resource usage,,Supportability - adaptability, maintainability, internation

28、alization, configurability,,The +,Implementation - resource limitations, languages and tools, hardware…,,Interface - constraints imposed by interfacing with external systems,,Operations - system management in its operational setting,,Packaging,,Legal - licensing and so forth,,Requirements Developmen

29、t,Get it written down (shalls),,Can be verified,,Get consensus with user,,Next,Use Cases,,Domain Models,,Object-Oriented Analysis,Use Cases, Domain Model,Bill Bond,,10/30/02,,Chapter 6 - Use Cases,Use case - Narrative description that describes sequence of events of an actor (external agent) using s

30、ystem to complete a process (documents responses).,,Actor,,Human,,Another system,,Example,Use case: Buy Items,,Actors: Customer, Cashier,,Description: A customer arrives at a checkout with items to purchase. The cashier records the purchase items and collects payment. On completion, the Customer lea

31、ves with the items.,,Use Case,No rigid format,,Alternative solutions,,Handled at end,,Mistake -identify individual steps as a use case,,Use case usually includes many steps,,,,Actor,External Entity,,Stimulates system,,Receives response,,Capitalize to identify,,Actor,Initiator actor,,Participating ac

32、tors,,Kinds of actors,,Roles that people play,,Computer systems,,Electrical or mechanical devices,,Identifying Use Cases,Actor-based,,Identify actors related to a system,,For each actor, identify the processes they initiate or participate in,,Event-based,,Identify the external events that the system

33、 must respond to,,Relate the events to actors and use cases,,UML Notation,,Traceability,Functions should all be allocated to Use Cases,,Via cross reference verify all functions have been allocated,,,System Boundary,Examples,,Hardware/software boundary of device/computer system,,Defines systems respo

34、nsibilities,,Depends on Intent,,Example,Log In,Refund,Buy Items,Refund,Buy Items,POST,Store,Cashier,Customer,Customer,,Use Case Refinement,Real,,Very concrete,,,Design details,,User interface,Essential,,Very abstract,Which best supports testing?,,Naming,Start with verb,,It is a process,,Decisions an

35、d Branching,Main:,,…,,If ____, see section X,,If ____, see section Y,,…,,X: …,,Y: …,,,Using Use Cases,Define system boundary, actors, use cases,,Write use cases in high-level format,,Draw Use Case diagram,,Relate Use Cases,,For critical, influential, risky use cases, expand detail,,Rank Use Cases fo

36、r implementation,,Chapter 7,,,Chapter 8 - Scheduling,Ranking and scheduling Use cases,,Assuming desired artifacts produced (requirements, use cases), transition to iterative development,,Ranking,Significant impact on architectural design,,Significant information and insight regarding design, with li

37、ttle effort,,Risky, time-critical, complex,,Significant research,,Primary processes,,Directly support increased revenue / decreased cost,,“Start Up〞,May not rank high,,Provides initialization used by other use cases,,Often “falls out〞,,Chapter 9 - System Sequence,System sequence diagram - for a part

38、icular scenario of a use case the events that external actors generate, their order,,Time proceeds downward,,Order of events follow use case,,,Construction,Draw line representing system as black box,,Identify each actor, draw line,,From use case, identify external events that each actor generates -

39、Illustrate on diagram,,Optionally include use case text,,System boundary must be clear,,Naming operations - begin with verb,,,,Chapter 10 - Domain Model,Representation of “real-world〞 things,,Static structure diagram,,Contents,,Concepts,,Associations between concepts,,Attributes of concepts,,Tool of

40、 communication,,,Not Software Design,Following should not be in model,,No software artifacts - window/database,,No responsibilities or methods,,Concept,Idea,,Thing,,Object,,May be defined using,,Symbol - word representing a concept,,Intension - definition of a concept,,Extension - set of examples to

41、 which the concept applies,,,Approach,Decompose domain into concepts,,Strategy to identify concepts,,Guideline - better to over specify with many fine-grained concepts, than to under specify it,,Do not exclude concept because requirements do not indicate any need to “remember〞 information or it has

42、no attributes,,Use domain vocabulary,,Concept Category List,Physical or tangible objects,,Specifications or descriptions of things,,Places,,Transactions,,Transaction line items,,Roles of people,,Containers of other things,,Things in a container,,Concept Category List,Other computer or mechanical sys

43、tems external to our system,,Organizations,,Events,,Processes,,Catalogs, manuals, books,,Records of finance, work, contracts, legal matters,,,Noun Phrase Identification,Noun and noun phrases in textual description of problem domain,,Some may be attributes,,Construction of Domain Model,List candidate

44、 concepts using Concept Category List, Noun Phrase Identification,,Draw domain model,,add associations necessary to record relationships for which there is a need to preserve some memory,,Add the attributes necessary to fulfill information requirements,,Example,,Concept or Attribute?,If we do not th

45、ink of some concept as a number or text in the real world, X is probably a concept, not an attribute,,,Specification,Description of item, distinct from item,,Use specification when:,,Deleting instances of things results in a loss of information,,It reduces redundant or duplicate information,,Chapter

46、 11- Adding Associations,Association - relationship between concepts that indicates some meaningful and interacting connection,,UML Association Notation,,Guidelines,Focus on associations for which knowledge of the relationship needs to be preserved for some duration,,It is more important to identify

47、 concepts than associations,,Too many associations tend to confuse domain model rather than illuminate it,,Avoid showing redundant or derivable associations,,Common Association List,A is a physical part of B,,A is a logical part of B,,A is physically contained in B,,A is logically contained in B,,A

48、is a description for B,,A is line item of a transaction/report in B,,A is known/logged/recorded/reported/ captured in B,,Common Association List,A is a member of B,,A is an organizational subunit of B,,A uses or manages B,,A communicates with B,,A is related to a transaction B,,A is next to B,,A is

49、owned by B,,High Priority,A is a physical or logical part of B,,A is physically or logically contained in B,,A is recorded in B,,,Remove associations not required by requirements, could change with requirements,,Association,Each end of an association is called a role,,Name,,Multiplicity expression,,

50、Naming associations,,TypeName VerbPhrase TypeName,,,Multiplicity,How many instances of type A can be associated with one instance of type B,,* zero or more,,1..* one or more,,1..40 one to forty,,5 exactly five,,3, 5, 8 three, five, eight,,Multiplicity,,,Chapter 12 - Adding Attributes,Attribut

51、e - logical data value of an object,,Prefer simple attribute types,,Boolean,,Date,,Number,,Text,,Time,,UML Attribute Notation,,Non Primitive Types,Use non primitive type if,,It is composed of separate sections - phone number, name of person,,Operations are associated with it, parsing/ validation - s

52、ocial security number,,Has other attributes - promotional price, start/ end date,,Quantity with unit - unit of currency,,Example,,,Chapter 13 - Contracts,Contract - document that describes what an operation commits to achieve, emphasizes what will happen (not how), common to express pre- and post-c

53、ondition state changes,,System operation contract - changes in overall system when operation is invoked,,Construction,Identify system operations from system sequence diagrams,,For each operation, construct a contract,,Write responsibilities section first,,Complete post-conditions section describing

54、state changes,,Instance creation and deletion,,Attribute modification,,Associations formaed and broken,,,Chapter 14 - Analysis To Design,Analysis - What,,Chapter 14 - Analysis To Design,Analysis - What,,Artifact,,Use Cases,,,Domain model,,,System Sequence Diagrams,,Contracts,,Answered,,What are domain processes?,,What are concepts, terms?,,What are system events and operations?,,What do the system operations do?,,Next Week,Object-Oriented Design,,Collaboration / Design Diagrams,,

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

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!

五月丁香婷婷狠狠色,亚洲日韩欧美精品久久久不卡,欧美日韩国产黄片三级,手机在线观看成人国产亚洲