©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 1 Component-based development l Building software from reusable components l Objectives.

Slides:



Advertisements
Similar presentations
Distributed Systems Architectures
Advertisements

Chapter 14 Design with Reuse.
IS301 – Software Engineering V:
Software Reuse and Component-Based Software Engineering
COM vs. CORBA.
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 31 Slide 1 Service-centric Software Engineering 1.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 12Slide 1 Software Design l Objectives To explain how a software design may be represented.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Design 2.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 9 Distributed Systems Architectures Slide 1 1 Chapter 9 Distributed Systems Architectures.
Software Reuse SEII-Lecture 28
Distributed Systems Architectures
7M701 1 Software Engineering Object-oriented Design Sommerville, Ian (2001) Software Engineering, 6 th edition: Chapter 12 )
Distributed Systems Architectures
Software Reuse Building software from reusable components Objectives
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 19 Slide 1 Component-based software engineering.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
CS 501: Software Engineering Fall 2000 Lecture 16 System Architecture III Distributed Objects.
- 1 - Component Based Development R&D SDM Theo Schouten.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
Software Engineering Module 1 -Components Teaching unit 3 – Advanced development Ernesto Damiani Free University of Bozen - Bolzano Lesson 2 – Components.
Building software from reusable components.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Design 1.
 1. Introduction  2. Development Life-Cycle  3. Current Component Technologies  4. Component Quality Assurance  5. Advantages and Disadvantages.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 18 Slide 1 Software Reuse 2.
©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 Engineering Reuse.
Distributed Software Engineering To explain the advantages and disadvantages of different distributed systems architectures To discuss client-server and.
©Ian Sommerville 2006Software Engineering, 8th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
Distributed Systems Architectures ©Ian Sommerville 2006.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 19 Slide 1 Component-based software engineering 1.
Engr. M. Fahad Khan Lecturer Software Engineering Department University Of Engineering & Technology Taxila.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
1 소프트웨어공학 강좌 Chap 9. Distributed Systems Architectures - Architectural design for software that executes on more than one processor -
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 11Slide 1 Chapter 11 Distributed Systems Architectures.
Distributed Systems Architectures
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 2Slide 1 Chapter 2 Computer-Based System Engineering As modified by Randy Smith.
Software Models (Cont.) 9/22/2015ICS 413 – Software Engineering1 -Component-based software engineering -Formal Development Model.
CS 240, Prof. Sarwar Slide 1 CS 240: Software Project Fall 2003 Sections 1 & 2 Dr. Badrul M. Sarwar San Jose State University Lecture #13.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 18 Slide 1 Software Reuse.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 14 Slide 1 Object-oriented Design.
CSC 480 Software Engineering Lecture 18 Nov 6, 2002.
Distribution and components. 2 What is the problem? Enterprise computing is Large scale & complex: It supports large scale and complex organisations Spanning.
CS 240, Prof. Sarwar Slide 1 CS 240: Software Project Fall 2003 Sections 1 & 2 Dr. Badrul M. Sarwar San Jose State University Lecture #23.
©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.
Slide 1 Service-centric Software Engineering. Slide 2 Objectives To explain the notion of a reusable service, based on web service standards, that provides.
Lecture 21: Component-Based Software Engineering
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
©Ian Sommerville 2000, Tom Dietterich 2001 Slide 1 Distributed Systems Architectures l Architectural design for software that executes on more than one.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
©Ian Sommerville 2007COTS-based System Engineering Slide 1 COTS-based System Engineering.
Dr D. Greer, Queens University Belfast ) Software Engineering Chapter 7 Software Architectural Design Learning Outcomes Understand.
1 Distributed Systems Architectures Distributed object architectures Reference: ©Ian Sommerville 2000 Software Engineering, 6th edition.
Software Reuse. Objectives l To explain the benefits of software reuse and some reuse problems l To discuss several different ways to implement software.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 12 Slide 1 Distributed Systems Architectures.
IS301 – Software Engineering V:
Software Reuse ©Ian Sommerville 2006.
Chapter 16 – Software Reuse
CSSSPEC6 SOFTWARE DEVELOPMENT WITH QUALITY ASSURANCE
Component--based development
Chapter 16 – Software Reuse
Distributed Systems Architectures
Presentation transcript:

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 1 Component-based development l Building software from reusable components l Objectives To explain the benefits and challenges of constructing software systems from existing components To introduce the concept of design frameworks and middleware

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 2 Software components l In most engineering disciplines, systems are designed by composing existing components that have been used in other systems l Software engineering has been more focused on original development but it is now recognised that to achieve better software, more quickly and at lower cost, we need to adopt a design process that is based on systematic reuse

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 3 CBSE l Component-based software engineering (CBSE) is an approach to software development that relies on reuse l It emerged from the failure of object-oriented development to support effective reuse. Single object classes are too detailed and specific l Components are more abstract than object classes and can be considered to be stand-alone service providers

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 4 Components l Components provide a service without regard to where the component is executing or its programming language A component is an independent executable entity that can be made up of one or more executable objects The component interface is published and all interactions are through the published interface l Components can range in size from simple functions to entire application systems

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 5 Component interfaces

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 6 Component abstractions l Functional abstraction The component implements a single function such as a mathematical function l Casual groupings The component is a collection of loosely related entities that might be data declarations, functions, etc. l Data abstractions The component represents a data abstraction or class in an object-oriented language l Cluster abstractions The component is a group of related classes that work together l System abstraction The component is an entire self-contained system

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 7 CBSE problems l Component incompatibilities may mean that cost and schedule savings are less then expected l Finding and understanding components l Managing evolution as requirements change in situations where it may be impossible to change the system components

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 8 COTS –based development l COTS - Commercial Off-The-Shelf systems l COTS systems are usually complete application systems that offer an API (Application Programming Interface) l Building large systems by integrating COTS systems is now a viable development strategy for some types of system e.g., E-commerce systems l Package-oriented programming (POP) is a step beyond COTS

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 9 COTS system integration problems l Lack of control over functionality and performance COTS systems may be less effective than they appear l Problems with COTS system inter-operability Different COTS systems may make different assumptions that means integration is difficult l No control over system evolution COTS vendors not system users control evolution l Support from COTS vendors COTS vendors may not offer support over the lifetime of the product

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 10 Application frameworks l Frameworks are a sub-system design made up of a collection of abstract and concrete classes and the interfaces between them l The sub-system is implemented by adding components to fill in parts of the design and by instantiating the abstract classes in the framework l Frameworks are moderately large entities that can be reused

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 11 Framework classes l System infrastructure frameworks Support the development of system infrastructures such as communications, user interfaces and compilers l Middleware integration frameworks Standards and classes that support component communication and information exchange l Enterprise application frameworks Support the development of specific types of application such as telecommunications or financial systems

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 12 Extending frameworks l Frameworks are generic and are extended to create a more specific application or sub-system l Extending the framework involves Adding concrete classes that inherit operations from abstract classes in the framework Adding methods that are called in response to events that are recognised by the framework l Problem with frameworks is their complexity and the time it takes to use them effectively

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 13 Model-view controller l System infrastructure framework for GUI design l Allows for multiple presentations of an object and separate interactions with these presentations

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 14 Middleware – CORBA l CORBA is an international standard for an Object Request Broker middleware to manage communications between distributed objects l Several implementation of CORBA are available l DCOM is an alternative approach by Microsoft l CORBA has been defined by the Object Management Group

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 15 Application structure l Application objects l Standard objects, defined by the OMG, for a specific domain e.g. insurance l Fundamental CORBA services such as directories and security management l Horizontal (i.e. cutting across applications) facilities such as user interface facilities

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 16 CORBA application structure

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 17 CORBA objects l CORBA objects are comparable, in principle, to objects in C++ and Java l They MUST have a separate interface definition that is expressed using a common language (IDL) similar to C++ l There is a mapping from this IDL to programming languages (C++, Java, etc.) l Therefore, objects written in different languages can communicate with each other

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 18 Object request broker (ORB) l The ORB handles object communications. It knows of all objects in the system and their interfaces l Using an ORB, the calling object binds an IDL stub that defines the interface of the called object l Calling this stub results in calls to the ORB which then calls the required object through a published IDL skeleton that links the interface to the service implementation

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 19 ORB-based communication

©Ian Sommerville 2000 Software Engineering, 6th edition. Slide 20 l Component-based software engineering relies on black-box components with defined requires and provides interfaces l COTS product reuse is concerned with the reuse of large, off-the-shelf systems l CORBA is a set of middleware standards that support distributed object architectures Key points