Objectives Explain the purpose and various phases of the traditional systems development life cycle (SDLC) Explain when to use an adaptive approach to.

Slides:



Advertisements
Similar presentations
Chapter 2: Approaches to System Development
Advertisements

Objectives Explain the purpose and various phases of the traditional systems development life cycle (SDLC) Explain when to use an adaptive approach to.
Systems Analysis and Design in a Changing World, 6th Edition
Objectives Explain the purpose and various phases of the traditional systems development life cycle (SDLC) Explain when to use an adaptive approach to.
Overview Traditional systems development life cycle (SDLC)
Chapter 2 Approaches to System Development
Systems Analysis and Design in a Changing World, 6th Edition
Ch 3 System Development Environment
Object-Oriented Analysis and Design
Chapter 1 Object-Oriented System Development
Introduction To System Analysis and Design
Chapter Extension 19 Alternative Development Techniques © 2008 Pearson Prentice Hall, Experiencing MIS, David Kroenke.
Object Oriented System Development with VB .NET
Week 1.
Chapter 1 The Systems Development Environment
Copyright 2004 Prentice-Hall, Inc. Essentials of Systems Analysis and Design Second Edition Joseph S. Valacich Joey F. George Jeffrey A. Hoffer Appendix.
Systems Analysis and Design in a Changing World, Fifth Edition
Objectives Explain the purpose and various phases of the traditional systems development life cycle (SDLC) Explain when to use an adaptive approach to.
Chapter 1 The Systems Development Environment Modern Systems Analysis and Design Sixth Edition Jeffrey A. Hoffer Joey F. George Joseph S. Valacich.
Introduction to Systems Analysis and Design
Chapter 1 The Systems Development Environment
Chapter 1 The Systems Development Environment
Introduction To System Analysis and design
The Systems Development Environment. Learning Objectives Define information systems analysis and design. Describe the different types of information systems.
Lesson 1 Week01.
The Design Discipline.
CIS 321—IS Analysis & Design
Chapter 2: Approaches to System Development
2Object-Oriented Analysis and Design with the Unified Process Objectives  Explain the purpose and various phases of the traditional systems development.
Objectives Explain the purpose and various phases of the traditional systems development life cycle (SDLC) Explain when to use an adaptive approach to.
Chapter 1 The Systems Development Environment
2 Systems Analysis and Design in a Changing World, Fourth Edition.
Satzinger Chp. 2 Part Part 4 of 4 2 Object-Oriented Analysis and Design with the Unified Process Testing Testing is critical discipline Testing activities.
Chapter 1: Introduction to Systems Analysis and Design
Chapter 1 The Systems Development Environment Modern Systems Analysis and Design Sixth Edition Jeffrey A. Hoffer Joey F. George Joseph S. Valacich.
Topic 1: Approaches to System Development
Copyright 2001 Prentice-Hall, Inc. Essentials of Systems Analysis and Design Joseph S. Valacich Joey F. George Jeffrey A. Hoffer Appendix A Object-Oriented.
Copyright 2002 Prentice-Hall, Inc. Modern Systems Analysis and Design Third Edition Jeffrey A. Hoffer Joey F. George Joseph S. Valacich Chapter 20 Object-Oriented.
Introduction To System Analysis and Design
Chapter 1 The Systems Development Environment Modern Systems Analysis and Design Sixth Edition Jeffrey A. Hoffer Joey F. George Joseph S. Valacich.
Chapter 9 Moving to Design
1 Systems Analysis and Design in a Changing World, Thursday, January 18, 2007.
Content The system development life cycle
1 ISA&D7‏/8‏/ ISA&D7‏/8‏/2013 Methodologies of the SDLC Traditional Approach to SDLC Object-Oriented Approach to SDLC CASE Tools.
Systems Analysis and Design in a Changing World, 3rd Edition
2 Systems Analysis and Design in a Changing World, Fifth Edition.
Systems Analysis and Design in a Changing World, Fourth Edition
Chapter 1 The Systems Development Environment Modern Systems Analysis and Design Fifth Edition Jeffrey A. Hoffer Joey F. George Joseph S. Valacich.
2 2009/10 Object Oriented Technology 1 Topic 2: Introduction to Object-Oriented Approach Reference: u Ch.16 Current Trends in System Development (Satzinger:
Systems Analysis and Design in a Changing World, 6th Edition
System Development 1 u Systems development life cycle (SDLC) l Provides overall framework for managing system development process u Two main approaches.
APPROACH TO SYSTEM DEVELOPMENT. SYSTEMS DEVELOPMENT LIFE CYCLE A project is a planned undertaking that has a beginning and an end and that produces a.
2 Systems Analysis and Design in a Changing World, Fourth Edition.
Chapter 4 Automated Tools for Systems Development Modern Systems Analysis and Design Third Edition 4.1.
The Systems Development Environment Systems Analysis and Design II.
2 Systems Analysis and Design in a Changing World, Fourth Edition.
Systems Analysis and Design in a Changing World, 6th Edition
2 Systems Analysis – ITEC 3155 Systems Analysis Tasks.
2Object-Oriented Analysis and Design with the Unified Process Objectives  Explain the purpose and various phases of the traditional systems development.
Objectives Explain the purpose and various phases of the traditional systems development life cycle (SDLC) Explain when to use an adaptive approach to.
Chapter 1: Introduction to Systems Analysis and Design
Business System Development
Modern Systems Analysis and Design Third Edition
Introduction to Software Engineering
Chapter 20 Object-Oriented Analysis and Design
Chapter 1: Introduction to Systems Analysis and Design
Systems development life cycle (SDLC)
Chapter 1: Introduction to Systems Analysis and Design
Presentation transcript:

Objectives Explain the purpose and various phases of the traditional systems development life cycle (SDLC) Explain when to use an adaptive approach to the SDLC in place of the more predictive traditional SDLC Describe how the more adaptive Unified Process (UP) life cycle uses iterative and incremental development Explain the differences between a model, a tool, a technique, and a methodology Object-Oriented Analysis and Design with the Unified Process

Objectives (continued) Describe the Unified Process as a comprehensive system development methodology that combines proven best practices with the iterative UP life cycle Describe the disciplines used in a UP development project Describe the key features of the object-oriented approach Explain how automated tools are used in system development Object-Oriented Analysis and Design with the Unified Process

Overview Traditional systems development life cycle (SDLC) Unified Process (UP) Iterative, incremental, adaptive approach to life cycle Nine disciplines: six for system development, three for support Review object-oriented (OO) concepts Describe computer support tools such as CASE Apply UP to the development project of RMO Object-Oriented Analysis and Design with the Unified Process

The Systems Development Life Cycle SDLC: process of building, deploying, using, and updating an information system Chief variations of SDLC Predictive: project planned entirely in advance Adaptive: planning leaves room for contingencies Pure approaches to SDLC are rare Most projects have predictive and adaptive elements Object-Oriented Analysis and Design with the Unified Process

Predictive versus adaptive approaches to the SDLC Figure 2-1 Predictive versus adaptive approaches to the SDLC Object-Oriented Analysis and Design with the Unified Process

The Systems Development Life Cycle Predictive approach Example: A company that want to convert its old, mainframe inventory system to a newer networked client/server system. Object-Oriented Analysis and Design with the Unified Process

The Traditional Predictive SDLC Approaches Five activities or phases in a project Planning, analysis, design, implementation, support Pure waterfall approach (predictive SDLC) Assumes project phases can be sequentially executed Project drops over the “waterfall” into the next phase Modified waterfall approach The phases of project must overlap, influencing and depending on each other. Object-Oriented Analysis and Design with the Unified Process

SDLC Phases and Objectives Figure 2-3 SDLC Phases and Objectives Object-Oriented Analysis and Design with the Unified Process

The Waterfall Approach to the SDLC Figure 2-4 The Waterfall Approach to the SDLC Object-Oriented Analysis and Design with the Unified Process

The Overlap of System Development Activities PROJECT PLANNING ADDITIONAL PROJECT MANAGEMENT TASKS ANALYSIS ADDITIONAL ANALYSIS ACTIVITIES DESIGN ADDITIONAL DESIGN ACTIVITIES IMPLEMENTATION SUPPORT Figure 2-5 The Overlap of System Development Activities Object-Oriented Analysis and Design with the Unified Process

The Newer Adaptive Approaches to the SDLC The spiral model: early form of adaptive SDLC Activities radiate from center starting point Prototypes are artifacts of each phase Iterative problem solving: repeats activities Several approaches to structuring iterations Define and implement the key system functions Focus on one subsystem at a time Define by complexity or risk of certain components Complete parts incrementally Object-Oriented Analysis and Design with the Unified Process

The Spiral Life Cycle Model Figure 2-6 The Spiral Life Cycle Model Object-Oriented Analysis and Design with the Unified Process

The Unified Process Life Cycle UP life cycle Includes (4) phases which consist of iterations Iterations are “mini-projects” Inception: develop and refine system vision Elaboration: define requirements and core architecture Construction: continue design and implementation Transition: move the system into operational mode Object-Oriented Analysis and Design with the Unified Process

The Unified Process System Development Life Cycle Figure 2-8 The Unified Process System Development Life Cycle Object-Oriented Analysis and Design with the Unified Process

UP Phases and Objectives Figure 2-9 UP Phases and Objectives Object-Oriented Analysis and Design with the Unified Process

Methodologies, Models, Tools, and Techniques Analysts have a wide variety of aids to help them complete activities and tasks in system development beyond SDLC. Object-Oriented Analysis and Design with the Unified Process

Methodologies and System Development Processes System development methodology Provides guidelines every activity in system development Includes specific models, tools, and techniques UP is a system development methodology Methodologies supported with documentation Object-Oriented Analysis and Design with the Unified Process

Models A model is a representation of an important aspect of the real world. Models come in many forms Physical analogs, mathematical, graphical System development models are highly abstract Depict inputs, outputs, processes, data, objects, interactions, locations, networks, and devices Unified Modeling Language (UML): standard notation PERT or Gantt charts: model project itself Object-Oriented Analysis and Design with the Unified Process

Some Models used in System Development Figure 2-10 Some Models used in System Development Object-Oriented Analysis and Design with the Unified Process

Tools Tool: software used to create models or components Example tools Project management software tools (Microsoft Project) Integrated development environments (IDEs) Code generators Computer-aided system engineering (CASE) Object-Oriented Analysis and Design with the Unified Process

Tools Integrated development environments (IDEs) is a software application that provides comprehensive facilities to computer programmers for software development. An IDE normally consists of a: source code editor, compiler and/or interpreter, build automation tools, and debugger (usually). Example: Eclipse, Mic. Visual Studio and recent versions of Netbeans Object-Oriented Analysis and Design with the Unified Process

Techniques Technique Example techniques Collection of guidelines Enables an analyst to complete an activity or task Example techniques Domain-modeling , use case modeling, software-testing, user-interviewing techniques, relational database design techniques Proven techniques are embraced as “Best Practices” Object-Oriented Analysis and Design with the Unified Process

Figure 2-13 Relationships of Models, Tools, and Techniques in a System Development Methodology Object-Oriented Analysis and Design with the Unified Process

The Unified Process as a System Development Methodology UP: object-oriented system development methodology , offered by Rational Software, which is now part of IBM. UP should be tailored to organizational and project needs Project will be use case driven Object-Oriented Analysis and Design with the Unified Process

The Unified Process as a System Development Methodology (continued) Use case Activity that the system carries out Basis for defining requirements and designs UP defines disciplines within each phase Discipline: set of functionally related activities Iterations concatenate activities from all disciplines Activities in each discipline produce artifacts; models, documents, source code, and executables Object-Oriented Analysis and Design with the Unified Process

UP Life Cycle with Phases, Iterations, and Disciplines Figure 2-15 UP Life Cycle with Phases, Iterations, and Disciplines Object-Oriented Analysis and Design with the Unified Process

The UP Disciplines Six main UP development disciplines Each iteration Business modeling, requirements, design, implementation, testing, and deployment Each iteration Similar to a mini-project Results in a completed portion of the system Three additional support disciplines Project management, configuration and change management, and environment Object-Oriented Analysis and Design with the Unified Process

Business Modeling Purpose: understand business environment Three major activities part of business modeling Understand surroundings Create the system vision (define - system objective, system capabilities and primary business benefits) Create business models Object-Oriented Analysis and Design with the Unified Process

Requirements Objective: document business requirements Key drivers of activities: discovery and understanding Activities list Gather detailed information Define functional and nonfunctional requirements Develop user interface dialogs Evaluate requirements with users Object-Oriented Analysis and Design with the Unified Process

Design Objective: design system based on requirements Six major activities in the design discipline Design support services architecture and deployment environment Design the software architecture Design use case realizations (the design of the s/ware that implements each use case) Design the database Design the system and user interfaces Design the system security and controls Object-Oriented Analysis and Design with the Unified Process

Implementation Objective: build or acquire needed system components Implementation activities Build software components Acquire software components Integrate software components Object-Oriented Analysis and Design with the Unified Process

Testing Testing is critical discipline Testing activities Define and conduct unit testing Define and conduct integration testing Define and conduct usability testing Define and conduct user acceptance testing In UP, acceptance testing occurs throughout the building phase Object-Oriented Analysis and Design with the Unified Process

Deployment Goal: conduct activities to make system operational Deployment activities Acquire hardware and system software Package and install components Train users Convert and initialize data Deployment activities prominent in transition phase Object-Oriented Analysis and Design with the Unified Process

Project Management Most important support discipline Project management activities Finalize the system and project scope Develop the project and iteration schedule Identify project risks and confirm feasibility Monitor and control the project’s plan Monitor and control communications Monitor and control risks and outstanding issues Object-Oriented Analysis and Design with the Unified Process

Configuration and Change Management As the project progresses, many changes occur in: Requirements Design Source code Executables The two activities in this discipline Develop change control procedures Manage models and software components Object-Oriented Analysis and Design with the Unified Process

Environment Managing development environment includes Available facilities Design of the workspace Forums for team communication and interaction Environment discipline activities Select and configure the development tools Tailor the UP development process Provide technical support services Object-Oriented Analysis and Design with the Unified Process

Overview of Object-Oriented Concepts OOA views system as a collection of objects Object: entity capable of responding to messages Languages: Simula, C++, Java, C#, Visual Basic .NET Object-oriented design (OOD) Defines additional types of communication objects Shows how the objects interact to complete tasks Refines definition of objects for implementation Object-oriented programming (OOP): object coding Object-Oriented Analysis and Design with the Unified Process

Recognizing the Benefits of OO Development Rationale for use in information systems Benefits of naturalness Reusability   Object-Oriented Analysis and Design with the Unified Process

Objects are More Natural OO approach mirrors human perception OOA, OOD, and OOP imitate perceptual processes by modeling classes of objects Some system developers resist OO development They have get used to procedural programming Many experienced developers have had difficulty learning the OO approach New programmers are more receptive to OO approach Object-Oriented Analysis and Design with the Unified Process

Classes of Objects Can Be Reused Classes of objects have a long shelf life Example: Customer class adaptability Reused in systems where customer objects needed Extended through inheritance to a new subclass Reused during analysis, design, or programming Classes may be stored, with implementation hidden, in class libraries Object-Oriented Analysis and Design with the Unified Process

Understanding Object-Oriented Concepts Object: thing with attributes and behaviors Types of objects User interface Problem domain objects Attributes are associated with data Behaviors are associated with methods, functions, and procedures Object-Oriented Analysis and Design with the Unified Process

Attributes and Methods in Problem Domain Objects Figure 2-18 Attributes and Methods in Problem Domain Objects Object-Oriented Analysis and Design with the Unified Process

Understanding Object-Oriented Concepts (continued) Class: defines what all objects of class represent Objects are instances of a class Customer object is an instance of a customer class Objects interact through messages Objects retain memory of transactions Object-Oriented Analysis and Design with the Unified Process

Example: UML diagram CheckingAccount class Corresponding code for simple checking account object attribute method Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Order-processing system where objects interact by sending messages Figure 2-20 Order-processing system where objects interact by sending messages Object-Oriented Analysis and Design with the Unified Process

Understanding Object-Oriented Concepts (continued) Objects maintain association relationships Encapsulation: combining attributes and methods into one unit Information hiding: separating specification from implementation Inheritance: extending the characteristics of a class Polymorphism: ability for dissimilar objects to respond to the same message Object-Oriented Analysis and Design with the Unified Process

Encapsulation Definition: Attributes (data) and behaviors (code) are encapsulated in to a single object. attribute setter method getter Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Encapsulation In many cases, an attribute of the object will have both a getter and a setter – not always the case What is always the case is that the getters and setters are used to control access to the attributes and this is a key part of encapsulation. Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Encapsulation Class shown in previous slide cannot be executed directly. Example of an application that uses CheckingAccount class to instantiate and use a CheckingAccount object. object Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Encapsulation The application shown in previous slide instantiate a CheckingAccount object, called myAccount, set the value of balance to 40.00 and then print that balance out. Output: Starting myEncapsulation….. Balance= 40.00 Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Information/ Data Hiding Definition: Access to all of an object’s attributes is tightly controlled. Accomplished by making all the attributes private. Attribute is set to private Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Information/ Data Hiding Trying to access the balance attribute directly from the myAccount object. myAccount.setBalance (40.00) Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Information/ Data Hiding Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Information/ Data Hiding If balance is declared to public, it will work but violates the concept of data hiding. Data hiding, as with many other object-oriented concepts, is a design decision. If the system is designed with attributes as private, the compiler can help with enforcing data hiding. If the classes are designed with public attributes, the application is not designed in an object-oriented manner. Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Inheritance Inheritance allows a class to inherit the attributes and methods of another class. Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Inheritance The Dog and Cat classes both inherit from Mammal. This means that a Dog class actually has the following attributes: eyeColor // inherited from Mammal barkFrequency // defined only for Dogs In the same vein, the Dog object has the following methods: getEyeColor // inherited from Mammal bark // defined only for Dogs superclass subclasses Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Polymorphism Ability for dissimilar objects to respond to the same message. Read below article: http://www.developer.com/tech/article.php/10923_3332401_2 Reference: The Object-Oriented Thought Process, 2nd Edition by Matt Weisfeld Object-Oriented Analysis and Design with the Unified Process

Tools to Support System Development CASE (Computer Aided System Engineering) Database repository for information system Set of tools that help analysts complete activities Sample artifacts: models, automatically generated code Variations on CASE Visual modeling tools Integrated application development tools Round-trip engineering tools Object-Oriented Analysis and Design with the Unified Process

A Case Tool Repository Contains All Information About the System Figure 2-24 A Case Tool Repository Contains All Information About the System Object-Oriented Analysis and Design with the Unified Process

Tools to Support System Development (continued) Microsoft Visio: emphasizes technical drawing Rational Rose CASE tool supporting object-oriented approach Strongly identified with UP methodology Together Pioneers round-trip engineering synchronizes graphical models with generated program code Leverages UML diagrams Object-Oriented Analysis and Design with the Unified Process

Visual Modeling Tool Rational Rose Displaying UML Diagrams Figure 2-26 Visual Modeling Tool Rational Rose Displaying UML Diagrams Object-Oriented Analysis and Design with the Unified Process

Tools to Support System Development (continued) Embarcadero Describe Visual Modeling Round-trip engineering Rational XDE Professional Integrates Microsoft Visual Studio.NET IDE Also provides visual modeling and round-trip Object-Oriented Analysis and Design with the Unified Process

Rational XDE Professional is integrated with Visual Studio .NET Figure 2-29 Rational XDE Professional is integrated with Visual Studio .NET Object-Oriented Analysis and Design with the Unified Process

Summary UP is an adaptive system development methodology SDLC: set of activities required to complete system development project Predictive SDLC: executes project in sequential phases (waterfall approach) Adaptive SDLC: accommodates change and phase overlap Spiral SDLC model introduces iterations (cycles) UP is an adaptive system development methodology Object-Oriented Analysis and Design with the Unified Process

Summary (continued) UP life cycle includes four phases-inception, elaboration, construction, and transition UP phases decomposed into one ore more iterations Iterations involve work in nine UP disciplines UP is object-oriented Object-oriented concepts: object, class, methods, encapsulation, associations, inheritance, polymorphism CASE: automation tools simplify development tasks Object-Oriented Analysis and Design with the Unified Process