Components, interfaces, and re-entrance Taciana Amorim Vanderlei

Slides:



Advertisements
Similar presentations
MicroKernel Pattern Presented by Sahibzada Sami ud din Kashif Khurshid.
Advertisements

Construction process lasts until coding and testing is completed consists of design and implementation reasons for this phase –analysis model is not sufficiently.
Design by Contract.
Copyright W. Howden1 Programming by Contract CSE 111 6/4/2014.
Lectures on File Management
Chapter 11 Component-Level Design
Component Patterns – Architecture and Applications with EJB copyright © 2001, MATHEMA AG Component Patterns Architecture and Applications with EJB JavaForum.
G Robert Grimm New York University Lightweight RPC.
Object-Oriented Programming with Java The Java Event Model Lecture 5.
Copyright W. Howden1 Lecture 13: Programming by Contract.
Software Requirements
Danius T. Michaelides, David E. Millard, Mark J. Weal, David De Roure Auld Leaky: A Contextual Open Hypermedia Link Server.
PowerPoint Presentation for Dennis, Wixom & Tegarden Systems Analysis and Design Copyright 2001 © John Wiley & Sons, Inc. All rights reserved. Slide 1.
Object-Oriented Programming with Java Lecture 2 The Java Event Model.
COMP 5138 Relational Database Management Systems Semester 2, 2007 Lecture 8A Transaction Concept.
חוזים – Contracts 1. Larman – Chapter 10 – SSDs 10.2 What are System Sequence Diagrams? (introduction) Use cases describe how external actors interact.
File System. NET+OS 6 File System Architecture Design Goals File System Layer Design Storage Services Layer Design RAM Services Layer Design Flash Services.
Dependency Injection and Model-View-Controller. Overview Inversion of Control Model-View-Controller.
1 Debugging and Testing Overview Defensive Programming The goal is to prevent failures Debugging The goal is to find cause of failures and fix it Testing.
Coupling and Cohesion Pfleeger, S., Software Engineering Theory and Practice. Prentice Hall, 2001.
Ch:10 Component Level Design Unit 4. What is Component? A component is a modular building block for computer software Because components reside within.
SAMANVITHA RAMAYANAM 18 TH FEBRUARY 2010 CPE 691 LAYERED APPLICATION.
Component frameworks Roy Kensmil. Historical trens in software development. ABSTRACT INTERACTIONS COMPONENT BUS COMPONENT GLUE THIRD-PARTY BINDING.
Cohesion and Coupling CS 4311
An Ontological Framework for Web Service Processes By Claus Pahl and Ronan Barrett.
UML-1 3. Capturing Requirements and Use Case Model.
1 Qualitative Reasoning of Distributed Object Design Nima Kaveh & Wolfgang Emmerich Software Systems Engineering Dept. Computer Science University College.
Distribution and components. 2 What is the problem? Enterprise computing is Large scale & complex: It supports large scale and complex organisations Spanning.
Chính phủ điện tử TS. Phạm Văn Tính Khoa CNTT, ĐH Nông Lâm TP.HCM
SOFTWARE DESIGN AND ARCHITECTURE LECTURE 13. Review Shared Data Software Architectures – Black board Style architecture.
Week 3: Requirement Analysis & specification
Seminar on Service Oriented Architecture Distributed Systems Architectural Models From Coulouris, 5 th Ed. SOA Seminar Coulouris 5Ed.1.
Component Patterns – Architecture and Applications with EJB copyright © 2001, MATHEMA AG Component Patterns Architecture and Applications with EJB Markus.
SOFTWARE DESIGN AND ARCHITECTURE LECTURE 15. Review Interaction-Oriented Software Architectures – MVC.
1 An infrastructure for context-awareness based on first order logic 송지수 ISI LAB.
Lectures 2 & 3: Software Process Models Neelam Gupta.
JavaScript Introduction and Background. 2 Web languages Three formal languages HTML JavaScript CSS Three different tasks Document description Client-side.
Object Design More Design Patterns Object Constraint Language Object Design Specifying Interfaces Review Exam 2 CEN 4010 Class 18 – 11/03.
Procedure Definitions and Semantics Procedures support control abstraction in programming languages. In most programming languages, a procedure is defined.
Appendix Object-Oriented Analysis and Design: Use Cases and Sequence Diagrams Modern Systems Analysis and Design Fifth Edition Jeffrey A. Hoffer Joey F.
Channels. Models for Communications Synchronous communications – E.g. Telephone call Asynchronous communications – E.g. .
Object Oriented Analysis & Design By Rashid Mahmood.
ITEC1301 Object-Oriented Systems Construction Lecture Notes #4 1.
High degree of user interaction Interactive Systems: Model View Controller Presentation-abstraction-control.
Coupling and Cohesion Pfleeger, S., Software Engineering Theory and Practice. Prentice Hall, 2001.
The Ingredients of Android Applications. A simple application in a process In a classical programming environment, the OS would load the program code.
The Structuring of Systems Using Upcalls David D. Clark (Presented by John McCall)
Component-Based Software Engineering Components and Interfaces Paul Krause and Sotiris Moschoyiannis.
Design by Contract Jim Fawcett CSE784 – Software Studio
Design by Contract Jim Fawcett CSE784 – Software Studio
Software Requirements
Component Based Software Engineering
Introduction to Triggers
TIM 58 Chapter 8: Class and Method Design
Class and Method Design
INFS 6225 – Object-Oriented Systems Analysis & Design
Component-Level Design
Verification and Validation Unit Testing
Seminarium on Component-based Software Engineering
Analysis models and design models
An Introduction to Software Architecture
Channels.
SAMANVITHA RAMAYANAM 18TH FEBRUARY 2010 CPE 691
Component-Based Software Engineering
Chapter 4: Threads.
Channels.
Channels.
CIS 375 Bruce R. Maxim UM-Dearborn
SOFTWARE DEVELOPMENT LIFE CYCLE
Software Development Process Using UML Recap
Presentation transcript:

Components, interfaces, and re-entrance Taciana Amorim Vanderlei

Contents Components and interfaces Direct and indirect interfaces Versions Interfaces as contract What belongs to a contract? Dress code – fomal or informal? Callbacks and contracts Example of callbacks and contracts From callbacks to objects Object re-entrance

Components and interfaces Interfaces are the means by which components connect. Technically, an interface is a set of named operations that can be invoked by clients. Each operation’s semantics is specified, and this specification plays a dual role as it serves both providers implementing the interface and clients using the interface.

Components and interfaces A component may either directly provide an interface or implement objects that, if made available to clients, provide interfaces. Interfaces directly provided by a component correspond to procedural interfaces of tradicional libraries. Such indirectly implemented interfaces correspond to object interfaces.

Direct and indirect interfaces A procedural (direct) interface to a component is modeled as an object interface of a static object within the component. An object (indirect) interface introduces an indirection called method dispatch or, sometimes, dynamic method lookup.

Versions Tradicional version management assumes that the versions of a component envolve at a single source. In a free market, the evolution of versions is more complex and management of version numbers can become a problem in its own right. With direct interfaces it suffices to ckeck versions at bind time, which is when a service is first requested. In indirect interfaces couple arbitrary third party. In a versioned system, care must be taken to avoid indirect coupling of parties that are of incompatible versions. The goal is to ensure that older and newer components are either compatible or clearly detected as incompatible.

Interfaces as contract The contract states what the client needs to do to use the interfaces and what the provider has to implement to meet the services promised by the interface. A contract is an appropriate approach, with pre- and post-conditions attached to every operation in the library.

What belongs to a contract? Safety and progress  Progress condition often rely on some form of temporal logic. They complement the safety conditions that can be expressed using invariants. Extra-functional requirements  The practice of including extra-functional specifications into a contract is not popular in the present, causing problems as performance and consume of resources. Specifying time and space requirements

Dress code – fomal or informal? None of the real-world laws are formal. New “interpretations” are found every day and tested in court. Different parts of a system can be specified using different degrees of formality – the preciseness of the specification have to be balanced against the critically of the target part.

Callbacks and contracts Callbacks are a common feature in procedural libraries that have to handle asynchronous events. A callback usually reverses the direction of the flow of controls, so a lower layer calls a procedure in a higher layer. The resulting contract are far less manageable than simple pre- and post-conditions. Validity of the library state is specified as part of a contract.

Callbacks and contracts Client Other party Library Calls Results Client installs callback Third party calls library Library invokes callback Callback queries library Callback returns Library returns Critical part The intermediate library state at the point of calling the callback may be reveled to clients.

Example of callbacks and contracts – A directory service DEFINITION Directory; IMPORT Files; (* details of no importance for this example *) TYPE Name = ARRAY OF CHAR; Notifier = PROCEDURE(IN name: Name); (* callback *) PROCEDURE ThisFile(n: Name):Files.File; (* pre n != “” *) (* post result = file named n or (result = NIL and no such file) *) PROCEDURE AddEntry(n: Name; f: Files.File); (* pre n != “” and f != NIL *) (* post ThisFile(n) = f *) PROCEDURE RemoveEntry(n: Name); (* pre n != “” *) (* post ThisFile(n) = NIL *) PROCEDURE RegisterNotifier(n: Notifier); (* pre n != NIL *) (* post n registered, will be called on AddEntry and RemoveEntry *) PROCEDURE UnregisterNotifier(n: Notifier); (* pre n != NIL *) (* post n unregistered, will no longer be called *)

Example of callbacks and contracts – A client of the directory service MODULE DirectoryDisplay: (* most details deleted *) IMPORT Directory; PROCEDURE Notifier(IN n: Directory.Name); BEGIN IF Directory.ThisFile(n) = NIL THEN (* entry under name n has been removed – delete n in display *) ELSE (* entry has been added under name n – include n in display *) END END Notifier; BEGIN Directory.RegisterNotifier(Notifier) END DirectoryDisplay.

From callbacks to objects Object references introduce linkage across arbitrary abstraction domains. It is certainly not as natural as with procedural abstraction. With object reference there is no need for explicit callback constructs as every method invocation is potencially a callback.

From callbacks to objects ClientText Model Display Calls Results Write insertNotification (remove caret mark) (update text display) (redisplay caret mark) Text view Message sequence occurring on insertion of a character into a text model that is displayed by a text view

Object re-entrance The object re-entrance is the situation in which an object´s method is invoked while another method is still executing. The real problem is observation of an object undergoing a state transition with inconsistent intermediate states becoming visible. Considering object re-entrance, the problem is when an object´s method is invoked while another method is still executing. Recursion and re-entrances become even more pressing problem when crossing the boundaries of components.

Object re-entrance User Interface Text Model Display Calls Results Type Write insertNotification (remove caret mark) (update text display) (redisplay caret mark) Text view Message sequence caused by a request to insert a typed character

Components, interfaces, and re-entrance Questions?