Figures – Chapter 16. Figure 16.1 Benefits of software reuse BenefitExplanation Increased dependabilityReused software, which has been tried and tested.

Slides:



Advertisements
Similar presentations
Object-Oriented Application Frameworks Much of the cost and effort stems from the continuous re- discovery and re-invention of core concepts and components.
Advertisements

Chapter 16 – Software Reuse
Chapter 2 – Software Processes
Software Reuse SEII-Lecture 28
Alternate Software Development Methodologies
Unified theory of software evolution Reengineering – Business process reengineering and software reengineering BPR model – Business definition, process.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 23 Slide 1 Software testing.
Software Reuse Building software from reusable components Objectives
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 8 Slide 1 Software Prototyping l Rapid software development.
Chapter 8 Object Design Reuse and Patterns. Finding Objects The hardest problems in object-oriented system development are: –Identifying objects –Decomposing.
Building software from reusable components.
Reuse Basic concepts. Rationale for reuse  Save calendar time  Save person hours  Reduce process risk  Increased quality  Standards compliance.
Introduction to Software Testing
Software Process Activities. Process activities Real software processes are inter-leaved sequences of technical, collaborative and managerial activities.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 23 Slide 1 Software testing.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 18 Slide 1 Software Reuse 2.
Problems with reuse – Increased maintenance costs; lack of tool support; not-invented- here syndrome; creating, maintaining, and using a component library.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 8 Slide 1 Software Prototyping l Rapid software development to validate requirements l.
Chapter 16 – Software Reuse
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 18 Slide 1 Software Reuse.
Software Engineering Muhammad Fahad Khan
Software Reuse Prof. Ian Sommerville
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 18 Slide 1 Software Reuse.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 14Slide 1 Design with Reuse l Building software from reusable components.
Software Reuse Course: # The Johns-Hopkins University Montgomery County Campus Fall 2004 Session 6 Lecture # 5 – October 12, 2004.
Software Engineering Reuse.
Software Product Families. Generative Programming Main text: Ian Sommerville, Software Engineering, 8 th edition, chapter 18 Additional readings: K. Czarnecki.
Engr. M. Fahad Khan Lecturer Software Engineering Department University Of Engineering & Technology Taxila.
SWE 316: Software Design and Architecture – Dr. Khalid Aljasser Objectives Lecture 11 : Frameworks SWE 316: Software Design and Architecture  To understand.
Customising Web Application Security Richard Wilson University of Melbourne, Australia Daniel Lowes University of Pretoria, South Africa.
©Ian Sommerville 1995/2000 (Modified by Spiros Mancoridis 1999) Software Engineering, 6th edition. Chapter 8 Slide 1 Software Prototyping l Animating and.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 4 Slide 1 Software Processes.
©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 1 Component-based development l Building software from reusable components l Objectives.
Chapter 11: Software Prototyping Omar Meqdadi SE 273 Lecture 11 Department of Computer Science and Software Engineering University of Wisconsin-Platteville.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 8 Slide 1 Software Prototyping l Rapid software development to validate requirements.
 CS 5380 Software Engineering Chapter 2 – Software Processes Chapter 2 Software Processes1.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 18 Slide 1 Software Reuse.
소프트웨어공학 강좌 1 Chap 7. Software Prototyping - Rapid software development to validate requirements -
Software Design Patterns (1) Introduction. patterns do … & do not … Patterns do... provide common vocabulary provide “shorthand” for effectively communicating.
Software Development Through Software Reuse, CASE tools, Lecture 8.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 14Slide 1 Chapter 14 Design with Reuse.
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 18 Slide 1 Software Reuse.
Chapter © 2012 Pearson Education, Inc. Publishing as Prentice Hall.
Software Reuse 1 Dr. Eman Alkhammash Taif University.
Software Prototyping Rapid software development to validate requirements.
Chapter 2 – Software Processes Lecture 1 Chapter 2 Software Processes1.
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 4 Slide 1 Software Processes.
Chapter 15 – Software Reuse Chapter 15 Software reuse117/11/2014.
IT323 - Software Engineering 2 1 Tutorial 4.  List the main benefits of software reuse 2.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 23 Slide 1 Software testing.
Chapter 7 Lecture 1 Design and Implementation. Design and implementation Software design and implementation is the stage in the software engineering process.
©Ian Sommerville 2007COTS-based System Engineering Slide 1 COTS-based System Engineering.
Tempus Software Maintenance and Evolution JMSE-SM&E Unit 4: Software Reuse (Building Software From Reusable Components) Prof. Mohammad A. Mikki Gaza, Palestine,
Why is Design so Difficult? Analysis: Focuses on the application domain Design: Focuses on the solution domain –The solution domain is changing very rapidly.
Tutorial 4 IT323.  Q1. As a software project manager in a company that specializes in the development of software for the offshore oil industry, you.
A Method for Improving Code Reuse System Prasanthi.S.
Software Reuse. Objectives l To explain the benefits of software reuse and some reuse problems l To discuss several different ways to implement software.
Chapter 15 – Software Reuse Chapter 15 Software reuse117/11/2014.
Chapter 16 – Software Reuse
Software Prototyping.
IS301 – Software Engineering V:
The Systems Engineering Context
Software Reuse ©Ian Sommerville 2006.
Chapter 16 – Software Reuse
Chapter 16 – Software Reuse
Software Reuse Objectives
CSSSPEC6 SOFTWARE DEVELOPMENT WITH QUALITY ASSURANCE
Chapter 16 – Software Reuse
Chapter 8, Design Patterns Introduction
Presentation transcript:

Figures – Chapter 16

Figure 16.1 Benefits of software reuse BenefitExplanation Increased dependabilityReused software, which has been tried and tested in working systems, should be more dependable than new software. Its design and implementation faults should have been found and fixed. Reduced process riskThe cost of existing software is already known, whereas the costs of development are always a matter of judgment. This is an important factor for project management because it reduces the margin of error in project cost estimation. This is particularly true when relatively large software components such as subsystems are reused. Effective use of specialistsInstead of doing the same work over and over again, application specialists can develop reusable software that encapsulates their knowledge. Standards complianceSome standards, such as user interface standards, can be implemented as a set of reusable components. For example, if menus in a user interface are implemented using reusable components, all applications present the same menu formats to users. The use of standard user interfaces improves dependability because users make fewer mistakes when presented with a familiar interface. Accelerated developmentBringing a system to market as early as possible is often more important than overall development costs. Reusing software can speed up system production because both development and validation time may be reduced.

Figure 16.2 Problems with reuse ProblemExplanation Increased maintenance costsIf the source code of a reused software system or component is not available then maintenance costs may be higher because the reused elements of the system may become increasingly incompatible with system changes. Lack of tool supportSome software tools do not support development with reuse. It may be difficult or impossible to integrate these tools with a component library system. The software process assumed by these tools may not take reuse into account. This is particularly true for tools that support embedded systems engineering, less so for object-oriented development tools. Not-invented-here syndromeSome software engineers prefer to rewrite components because they believe they can improve on them. This is partly to do with trust and partly to do with the fact that writing original software is seen as more challenging than reusing other people’s software. Creating, maintaining, and using a component library Populating a reusable component library and ensuring the software developers can use this library can be expensive. Development processes have to be adapted to ensure that the library is used. Finding, understanding, and adapting reusable components Software components have to be discovered in a library, understood and, sometimes, adapted to work in a new environment. Engineers must be reasonably confident of finding a component in the library before they include a component search as part of their normal development process.

Figure 16.3 The reuse landscape

Figure 16.4 Approaches that support software reuse ApproachDescription Architectural patternsStandard software architectures that support common types of application systems are used as the basis of applications. Described in Chapters 6, 13, and 20. Design patternsGeneric abstractions that occur across applications are represented as design patterns showing abstract and concrete objects and interactions. Described in Chapter 7. Component-based developmentSystems are developed by integrating components (collections of objects) that conform to component-model standards. Described in Chapter 17. Application frameworksCollections of abstract and concrete classes are adapted and extended to create application systems. Legacy system wrappingLegacy systems (see Chapter 9) are ‘wrapped’ by defining a set of interfaces and providing access to these legacy systems through these interfaces. Service-oriented systemsSystems are developed by linking shared services, which may be externally provided. Described in Chapter 19. Software product linesAn application type is generalized around a common architecture so that it can be adapted for different customers. COTS product reuseSystems are developed by configuring and integrating existing application systems. ERP systemsLarge-scale systems that encapsulate generic business functionality and rules are configured for an organization. Configurable vertical applicationsGeneric systems are designed so that they can be configured to the needs of specific system customers. Program librariesClass and function libraries that implement commonly used abstractions are available for reuse. Model-driven engineeringSoftware is represented as domain models and implementation independent models and code is generated from these models. Described in Chapter 5. Program generatorsA generator system embeds knowledge of a type of application and is used to generate systems in that domain from a user-supplied system model. Aspect-oriented software development Shared components are woven into an application at different places when the program is compiled. Described in Chapter 21.

Figure 16.5 The Model-View-Controller pattern

Figure 16.6 Inversion of control in frameworks

Figure 16.7 The architecture of a resource allocation system

Figure 16.8 The product line architecture of a vehicle dIspatcher system

Figure 16.9 Product instance development

Figure Deployment-time configuration

Figure COTS-solution and COTS-integrated systems COTS-solution systemsCOTS-integrated systems Single product that provides the functionality required by a customer Several heterogeneous system products are integrated to provide customized functionality Based around a generic solution and standardized processes Flexible solutions may be developed for customer processes Development focus is on system configurationDevelopment focus is on system integration System vendor is responsible for maintenanceSystem owner is responsible for maintenance System vendor provides the platform for the system System owner provides the platform for the system

Figure The architecture of an ERP system

Figure A COTS-integrated procurement system

Figure Application wrapping