Aspect Weaving DyMAC middleware. by Tonje Klykken, INF5360 May 6th 2008
|
|
- Esther Douglas
- 5 years ago
- Views:
Transcription
1 Aspect Weaving DyMAC middleware by Tonje Klykken, INF5360 May 6th 2008
2 Agenda Brief AOP/AOSD motivation and concepts Problem description and refinement DyMAC component model DyMAC architecture model Analysis and results Conclusion
3 Presented paper B. Lagaisse and W. Joosen. True and Transparent Distributed Composition of Aspect-Components. In Proceedings Middleware'06, volume 4290 of Lecture Notes in Computer Science, 2006.
4 Aspect-oriented programming Security and logging are examples of functionality that represent cross-cutting concerns. Scattered code Basic functionality is cluttered Modifying and customizing the code is more difficult AOP aids the programmer by making it possible to modularize the cross-cutting concerns Example from Wikipedia [2]: a security module can include advice that performs a security check before accessing a bank account before() : loginbankacc() { checksecurity(); }
5 AO concepts (I) An aspect encapsulates: a behaviour advice (typed before, after and around ) instructions as to where, when and how to invoke the behaviour. A join point : defines when the advice can run A point cut: specifies of a set of join points When execution reaches a joinpoint, the associated advice is executed.
6 AO concepts (II) Joinpoints represent dynamic runtime conditions that arise during program execution The set of joinpoints can be specified in a pointcut designator where the kind and context of the joinpoint is described Example from Wikipedia: pointcut set() : execution(* set*(*) ) && this(point) && within(com.company.*); Context of a joinpoint may be the message signature, the identity of the caller/callee etc
7 Banking example Banking example
8 Problem (I) In state-of-the-art AOP, context information is limited to local information Distributed joinpoints are more advanced and will transparently distribute the basic concept of a joinpoint The context information must refer to components that are not local and on a distributed infrastructure To express these runtime conditions and express compositions, we need support for aspects with 3 key features
9 Problem (II) 3 key features: Remote pointcuts Evaluate on calls and executions of remote method invocation Evaluate on distributed context Remote advice Transparently executed in a remote enviroment Component semantics Clearly defined interfaces Supporting third party composition and interaction with other aspects
10 Problem refinement Advanced remote pointcuts Transparent remote advice with full semantics Unified aspect-component model
11 Advanced remote pointcuts Remote pointcuts that are able to refer to joinpoints before and after calling and executing remote method invocations in a distrbuted system can evaluate over contextual properties of the components involved allows to evaluate over contextual properties about the distributed location of sending and receiving component
12 Transparent remote advice with full semantics Transparent remote execution of advices based on deployment specification of an advising component Remote before, after and around advice with full remote semantics
13 Unified aspect-component model Unification of the entities Components are aspects, aspects are components Reusability (third party) Unification of interactions Advices and methods Considered normal remote method invocations Subject to aspect-oriented composition
14 State-of-the-art AO middleware Does not meet the challenges above, for instance: Contextual information for pointcut expressions is too limited Remote around advice with full remote semantics is not supported
15 Claim None of the initiatives in the domain of AO-middleware have defined a complete solution to the challenges above The paper claims that DyMAC offers a true and transparent distributed composition of aspect-components. it s component and composition model offers a solution for the three challenges
16 DyMAC middleware Basic concepts of the component model How the middleware supports aspect-oriented composition in a distributed environment and the concepts of the component and composition model Basic architecture model
17 DyMAC basic component model Each DyMAC component has 2 interfaces Implementation of a component Descriptors
18 Each DyMAC component has 2 interfaces Create-interface Specifies how to instantiate the component Can contain several create methods Instance-interface Specifies the methods the component-instance offers From BasicBanking example:
19 Implementation For each create-method a constructor is implemented in the create-interface Implements the instance-interface From BasicBanking example:
20 Descriptors Component descriptor Application descriptor Deployment descriptor
21 Component descriptor Defines: The component name The provided interfaces Create Instance The dependencies The required interfaces Defined by: Dependency name Expected interfaces The implementation file Note: Example is taken from another article [1] by the same authors
22 Application descriptor Defines: Application name Set of components used By referral to their descriptor Composition of components Can be both normal compositions and aspect-oriented compositions
23 Deployment descriptor (I) The components are deployed across a distributed infrastructure Hostgroup Host Host Framework instance Application domain Application
24 Deployment descriptor (II) Defines: The deployment location of the components: For remote components Location is unique and is defined by: The host Framework instance Application domain For local components: Deployed in every application domain
25 DyMAC supports aspect-oriented composition AO compositions are defined in the application descriptor They have 2 main parts: The component providing the aspect behaviour and its instantiation scope A set of bindings, where each binding: Defines a pointcut Refers to an advice-method of the advising component Specifies an advice type
26 Pointcut expressions (I) Logical expressions that evaluates on: Kind of joinpoint (call or execution) Contextual properties: Component-related properties (joinpoint model) Message signature Dependancy and interface names Component names Name of distributed application Infrastructure-related properties Host names Host groups Application domains
27 Pointcut expressions (II) All properties have a default value: all Pointcuts can be remote both implicitly and explicitly
28 Advice Supported advice types in DyMAC Before-advice After-advice Around-advice Replaces the invocation it advises Proceed operation
29 Specifying Advice Methods Methods defined in the component interface may be used as advice Advice must then be specified The advice Supports, Requires or Prohibits a kind of joinpoint Kinds of joinpoints: BeforeCall, AfterCall, AroundCall BeforeExecution, AfterExecution, AroundExecution
30 Execution semantics of advice Advice is considered a normal remote method invocation when called from the joinpoint context
31 Defining Distributed Instantiation Scope Aspect scopes define the creation moment and usage scope of the component instance State-of-the-art AOP instantiation scopes: per joinpoint / class / instance etc DyMAC extends them with distributed instantiation scopes: Singleton per hostgroup / host / application domain etc
32 Middleware Architecture Top-level architecture AspectBinder Distributed joinpoint infrastructure Before a remote invocation is called or executed Remote advice coordination infrastructure Instance management Component factory Distributed instance registry
33 Top-level architecture Each DyMAC framework can host multiple application domains for different DyMAC applications
34 Top-level architecture
35 Framework middleware Deployer distributes the application binaries and descriptors to the framework middleware to store them on the ApplicationRepository Framework facade deploys, starts up, stops and undeploys applications on the framework Application descriptor is handled by the ApplicationParser and an ApplicationSpec model is built.
36 Application middleware Framework middleware instantiates an application domain and loads the application middleware into it The application middleware loads and manages the different components deployed in its application domain. After the ApplicationType metamodel is created, we have a list of method definitions with empty advice chains. When the application is running, InterceptionCore processes the remote invocations between components
37 AspectBinder Handles the bindings defined in AO compositions For each binding, the properties of pointcuts known at loadtime are evaluated If ok, an advice thunk is inserted into the advice chain of the method. Advice thunk defines A set of properties to evaluate at runtime Advice method
38 InterceptionCore Two important services: Distributed joinpoint infrastructure Creates and manages the runtime representations of distributed joinpoints Remote advice coordinator Selects and evaluates advice thunks for a joinpoint An advice handler is instantiated when advice needs to be executed for a certain joinpoint A list of advices matching the joinpoint is given to the new instance
39 Chattiness To avoid chattiness there have been made some architectural decisions When a component is intitiated, the component s context properties are stored in its proxy Every remote client of a component receives the component s context properties together with the proxy
40 Component factory The factory instatiantes the components looks up the dependancy name binds a component to it creates an instance of the component
41 Distributed instance registry When receiving a new instantiation request: Checks if it already is registered If so, the registry returnes a proxy to the instance If not, the components are registered in the aspect registry at its deployment location Application middleware has a local cache of the aspect registry Reduces chattiness
42 Evaluation Evaluate the runtime overhead by the middleware platform to support the features of the component model Increased data access Increased network usage Increased usage of computation resources Compared runtime overhead between AO: application using the.net implementation of DyMAC State-of-the-art: application using.net remoting infrastructure
43 Performance analysis Data access Main performance bottleneck Network overhead Number of messages Message size Measured with 4 different messages between two localhost processes and on a 100MBit network If used for single process, single user AOP applications, they say that framework overhead is significant For large-scale distributed enterprise applications, they say the overhead is acceptable As parameters gets larger, the relative overhead gets smaller
44 Result They came to the result that the runtime overhead of DyMAC is acceptable in a distributed application The network/message size overhead is the penalty
45 Conclusion AOSD is a promising technology that can assist in improving expressing complex compositions effectively DyMAC fulfills the three key features/challenges desribed in the beginning of the presentation
46 Other resources used [1] Aspectual Dependencies: Towards Pure Black-Box Aspect-Oriented Composition in Component Models, B. Laigaisse and W. Joosen, WCOP 2007 Components beyond Reuse, URL: [2] Aspect-oriented programming, Wikipedia URL:
True and Transparent Distributed Composition of Aspect-Components
True and Transparent Distributed Composition of Aspect-Components Bert Lagaisse and Wouter Joosen Dept. of Computer Science, K.U.Leuven, Belgium {Bert.Lagaisse, Wouter.Joosen}@cs.kuleuven.be Abstract.
More information{b.surajbali, p.grace
ReCycle: Resolving Cyclic Dependencies in Dynamically Reconfigurable Aspect Oriented Middleware Bholanathsingh Surajbali, Paul Grace and Geoff Coulson Computing Department, Lancaster University Lancaster,
More informationAO-OpenCom: An AO-Middleware Architecture supporting flexible Dynamic Reconfiguration
AO-OpenCom: An AO-Middleware Architecture supporting flexible Dynamic Reconfiguration Bholanathsingh Surajbali Smart Research and Development CAS Software AG Karlsruhe, Germany b.surajbali@cas.de Paul
More informationInformation systems modeling. Tomasz Kubik
Information systems modeling Tomasz Kubik Aspect-oriented programming, AOP Systems are composed of several components, each responsible for a specific piece of functionality. But often these components
More informationAJDT: Getting started with Aspect-Oriented Programming in Eclipse
AJDT: Getting started with Aspect-Oriented Programming in Eclipse Matt Chapman IBM Java Technology Hursley, UK AJDT Committer Andy Clement IBM Java Technology Hursley, UK AJDT & AspectJ Committer Mik Kersten
More informationEVALUATING DATA STRUCTURES FOR RUNTIME STORAGE OF ASPECT INSTANCES
MASTER THESIS EVALUATING DATA STRUCTURES FOR RUNTIME STORAGE OF ASPECT INSTANCES Andre Loker FACULTY OF ELECTRICAL ENGINEERING, MATHEMATICS AND COMPUTER SCIENCE (EEMCS) CHAIR OF SOFTWARE ENGINEERING EXAMINATION
More informationAOSA - Betriebssystemkomponenten und der Aspektmoderatoransatz
AOSA - Betriebssystemkomponenten und der Aspektmoderatoransatz Results obtained by researchers in the aspect-oriented programming are promoting the aim to export these ideas to whole software development
More informationA Reflective Framework for Fine-Grained Adaptation of Aspect-Oriented Compositions
A Reflective Framework for Fine-Grained Adaptation of Aspect-Oriented Compositions Paul Grace, Bert Lagaisse, Eddy Truyen, and Wouter Joosen Department of Computer Science, K. U. Leuven, Leuven, Belgium
More informationModularizing Web Services Management with AOP
Modularizing Web Services Management with AOP María Agustina Cibrán, Bart Verheecke { Maria.Cibran, Bart.Verheecke@vub.ac.be System and Software Engineering Lab Vrije Universiteit Brussel 1. Introduction
More informationA short introduction to INF329. Spring AOP
A short introduction to INF329 Spring AOP Introduction to AOP AOP is an abbreviation for aspectoriented programming Aspect-oriented programming is a new paradigm in programming, seperating functionality
More informationApplying Aspect Oriented Programming on Security
Original Article Applying Aspect Oriented Programming on Security Mohammad Khalid Pandit* 1, Azra Nazir 1 and Arutselvan M 2 1 Department of computer Science and engineering, National institute of technology
More informationDesign Patterns. SE3A04 Tutorial. Jason Jaskolka
SE3A04 Tutorial Jason Jaskolka Department of Computing and Software Faculty of Engineering McMaster University Hamilton, Ontario, Canada jaskolj@mcmaster.ca November 18/19, 2014 Jason Jaskolka 1 / 35 1
More informationDesign Patterns. Manuel Mastrofini. Systems Engineering and Web Services. University of Rome Tor Vergata June 2011
Design Patterns Lecture 1 Manuel Mastrofini Systems Engineering and Web Services University of Rome Tor Vergata June 2011 Definition A pattern is a reusable solution to a commonly occurring problem within
More informationYoung-Woo Kwon 1, Eli Tilevich 1, and Taweesup Apiwattanapong 2
DECEMBER 3 rd, 2009 URBANA, ILLINOIS Young-Woo Kwon 1, Eli Tilevich 1, and Taweesup Apiwattanapong 2 1 Software Innovations Lab 2 NECTEC Dept. of Computer Science Virginia Tech Criminal try evidence {
More informationAspect-Orientation from Design to Code
Aspect-Orientation from Design to Code Iris Groher Siemens AG, CT SE 2 Otto-Hahn-Ring 6 81739 Munich, Germany groher@informatik.tu-darmstadt.de Thomas Baumgarth Siemens AG, CT SE 2 Otto-Hahn-Ring 6 81739
More informationAspect-Oriented Programming with C++ and AspectC++
Aspect-Oriented Programming with C++ and AspectC++ AOSD 2007 Tutorial University of Erlangen-Nuremberg Computer Science 4 Presenters Daniel Lohmann dl@aspectc.org University of Erlangen-Nuremberg, Germany
More informationIdioms for Building Software Frameworks in AspectJ
Idioms for Building Software Frameworks in AspectJ Stefan Hanenberg 1 and Arno Schmidmeier 2 1 Institute for Computer Science University of Essen, 45117 Essen, Germany shanenbe@cs.uni-essen.de 2 AspectSoft,
More informationJava J Course Outline
JAVA EE - J2SE - CORE JAVA After all having a lot number of programming languages. Why JAVA; yet another language!!! AND NOW WHY ONLY JAVA??? CHAPTER 1: INTRODUCTION What is Java? History Versioning The
More informationSocket attaches to a Ratchet. 2) Bridge Decouple an abstraction from its implementation so that the two can vary independently.
Gang of Four Software Design Patterns with examples STRUCTURAL 1) Adapter Convert the interface of a class into another interface clients expect. It lets the classes work together that couldn't otherwise
More informationObject Oriented Paradigm
Object Oriented Paradigm Ming-Hwa Wang, Ph.D. Department of Computer Engineering Santa Clara University Object Oriented Paradigm/Programming (OOP) similar to Lego, which kids build new toys from assembling
More informationSpring Interview Questions
Spring Interview Questions By Srinivas Short description: Spring Interview Questions for the Developers. @2016 Attune World Wide All right reserved. www.attuneww.com Contents Contents 1. Preface 1.1. About
More informationDesign Pattern. CMPSC 487 Lecture 10 Topics: Design Patterns: Elements of Reusable Object-Oriented Software (Gamma, et al.)
Design Pattern CMPSC 487 Lecture 10 Topics: Design Patterns: Elements of Reusable Object-Oriented Software (Gamma, et al.) A. Design Pattern Design patterns represent the best practices used by experienced
More informationTECHNISCHEBERICHTE TECHNICALREPORTS
Fakultät Informatik TECHNISCHEBERICHTE TECHNICALREPORTS ISSN 1430-211XX TUD-FI15-02-Juli 2015 Somayeh Malakuti, Mariam Zia Software Technology group Adopting Architectural Event Modules for Modular Coordination
More informationCourse 6 7 November Adrian Iftene
Course 6 7 November 2016 Adrian Iftene adiftene@info.uaic.ro 1 Recapitulation course 5 BPMN AOP AOP Cross cutting concerns pointcuts advice AspectJ Examples In C#: NKalore 2 BPMN Elements Examples AOP
More informationSoftware Design Patterns. Background 1. Background 2. Jonathan I. Maletic, Ph.D.
Software Design Patterns Jonathan I. Maletic, Ph.D. Department of Computer Science Kent State University J. Maletic 1 Background 1 Search for recurring successful designs emergent designs from practice
More informationApproach for Modeling Aspects in Architectural Views
Approach for Modeling Aspects in Architectural Views ABSTRACT This document presents the approach for modeling aspects in architectural views. It builds on earlier deliverables that have not explicitly
More informationChapter 7. Modular Refactoring. 7.1 Introduction to Modular Refactoring
Chapter 7 Modular Refactoring I n this chapter, the role of Unified Modeling Language (UML) diagrams and Object Constraint Language (OCL) expressions in modular refactoring have been explained. It has
More informationOdysseas Papapetrou and George A. Papadopoulos
From Components to Services: Evolutions and Trends in CBSE World Scientific, 2005 CHAPTER X ENHANCING COMPONENT-BASED SOFTWARE DEVELOPMENT WITH ASPECT ORIENTED PROGRAMMING Odysseas Papapetrou and George
More informationInternational Association of Scientific Innovation and Research (IASIR) (An Association Unifying the Sciences, Engineering, and Applied Research)
International Association of Scientific Innovation and Research (IASIR) (An Association Unifying the Sciences, Engineering, and Applied Research) ISSN (Print): 2279-0047 ISSN (Online): 2279-0055 International
More informationDESIGN PATTERN - INTERVIEW QUESTIONS
DESIGN PATTERN - INTERVIEW QUESTIONS http://www.tutorialspoint.com/design_pattern/design_pattern_interview_questions.htm Copyright tutorialspoint.com Dear readers, these Design Pattern Interview Questions
More informationAspect-Oriented Programming
Aspect-Oriented Programming Based on the Example of AspectJ Prof. Harald Gall University of Zurich, Switzerland software evolution & architecture lab AOP is kind of a complicated one for me ( ) the idea
More informationExploring Possibilities for Symmetric Implementation of Aspect-Oriented Design Patterns in Scala
Exploring Possibilities for Symmetric Implementation of Aspect-Oriented Design Patterns in Scala Pavol PIDANIČ Slovak University of Technology in Bratislava Faculty of Informatics and Information Technologies
More informationTowards a Reconfigurable Middleware Architecture for Pervasive Computing Systems
Towards a Reconfigurable Middleware Architecture for Pervasive Computing Systems Gustavo G. Pascual, Lidia Fuentes, and Mónica Pinto E.T.S.I. Informática, Universidad de Málaga {gustavo,lff,pinto}@lcc.uma.es
More informationAspect-Based Workflow Evolution
Aspect-Based Workflow Evolution Boris Bachmendo and Rainer Unland Department of Mathematics and Computer Science University of Essen, D - 45117 Essen {bachmendo, unlandr}@cs.uni-essen.de Abstract. In this
More informationChapter 32. Aspect-Oriented Software Development (AOSD) Ian Sommerville 2006 Software Engineering. Chapter 32 Slide 1
Chapter 32 Aspect-Oriented Software Development (AOSD) Ian Sommerville 2006 Software Engineering. Chapter 32 Slide 1 Objectives To explain the principle of separation of concerns in software development
More informationIn this Lecture you will Learn: Design Patterns. Patterns vs. Frameworks. Patterns vs. Frameworks
In this Lecture you will Learn: Design Patterns Chapter 15 What types of patterns have been identified in software development How to apply design patterns during software development The benefits and
More informationJBoss WS User Guide. Version: CR1
JBoss WS User Guide Version: 3.0.0.CR1 1. JBossWS Runtime Overview... 1 2. Creating a Web Service using JBossWS runtime... 3 2.1. Creating a Dynamic Web project... 3 2.2. Configure JBoss Web Service facet
More informationImplementing a Web Service p. 110 Implementing a Web Service Client p. 114 Summary p. 117 Introduction to Entity Beans p. 119 Persistence Concepts p.
Acknowledgments p. xvi Introduction p. xvii Overview p. 1 Overview p. 3 The Motivation for Enterprise JavaBeans p. 4 Component Architectures p. 7 Divide and Conquer to the Extreme with Reusable Services
More informationArchitecture based adaptation middleware. Student presentation inf th February 2008 Eli Gjørven
Architecture based adaptation middleware Student presentation inf5360 19 th February 2008 Eli Gjørven eligj@simula.no Overview Recap Self adaptation (Oreizy) MADAM SAFRAN Summary Criterias (Oreizy) Comparison
More informationJBoss WS User Guide. Version: GA
JBoss WS User Guide Version: 1.0.1.GA 1. JBossWS Runtime Overview... 1 2. Creating a Web Service using JBossWS runtime... 3 2.1. Creating a Dynamic Web project... 3 2.2. Configure JBoss Web Service facet
More informationAspectC++ A Language Overview
AspectC++ A Language Overview c 2005 Olaf Spinczyk Friedrich-Alexander University Erlangen-Nuremberg Computer Science 4 May 20, 2005 This is an overview about the AspectC++ language, an
More informationVrije Universiteit Brussel - Belgium Faculty of Sciences In Collaboration with Ecole des Mines de Nantes - France
Vrije Universiteit Brussel - Belgium Faculty of Sciences In Collaboration with Ecole des Mines de Nantes - France 2005 VRIJE UNIVERSITEIT BRUSSEL SCIENTIA VINCERE TENEBRAS ECOLE DES MINES DE NANTES DHAMACA:
More informationOn Hierarchical, parallel and distributed components for Grid programming
On Hierarchical, parallel and distributed components for Grid programming Francoise Baude, Denis Caromel, Matthieu Morel www.inria.fr/oasis/proactive OASIS Team INRIA -- CNRS - I3S -- Univ. of Nice Sophia-Antipolis
More informationAgent-Enabling Transformation of E-Commerce Portals with Web Services
Agent-Enabling Transformation of E-Commerce Portals with Web Services Dr. David B. Ulmer CTO Sotheby s New York, NY 10021, USA Dr. Lixin Tao Professor Pace University Pleasantville, NY 10570, USA Abstract:
More informationDepartment of Computer
Department of Computer Science @VUB Department of Computer Science 80+ Researchers 10 professors 15 post-doc s 55 pre-doc s Software and Programming Language Engineering PROG SSEL Web- and Information
More informationAnalyzing effect of Aspect Oriented concepts in design and implementation of design patterns with case study of Observer Pattern
Analyzing effect of Aspect Oriented concepts in design and implementation of design patterns with case study of Observer Pattern Deepali A. Bhanage 1, Sachin D. Babar 2 Sinhgad Institute of Technology,
More informationIdentification of Differences Between Aspect-Oriented Programs. Marija Katic, PhD Student
Identification of Differences Between Aspect-Oriented Programs Marija Katic, PhD Student University of Zagreb, Faculty of Electrical Engineering and Computing Department of Applied Computing Content Aspect-Oriented
More informationAOP 101: Intro to Aspect Oriented Programming. Ernest Hill
AOP 101: Intro to Aspect Oriented Programming ernesthill@earthlink.net AOP 101-1 AOP 101: Aspect Oriented Programming Goal of Software History of Programming Methodology Remaining Problem AOP to the Rescue
More informationJBoss SOAP Web Services User Guide. Version: M5
JBoss SOAP Web Services User Guide Version: 3.3.0.M5 1. JBoss SOAP Web Services Runtime and Tools support Overview... 1 1.1. Key Features of JBossWS... 1 2. Creating a Simple Web Service... 3 2.1. Generation...
More informationSpring & Hibernate. Knowledge of database. And basic Knowledge of web application development. Module 1: Spring Basics
Spring & Hibernate Overview: The spring framework is an application framework that provides a lightweight container that supports the creation of simple-to-complex components in a non-invasive fashion.
More informationKINGS COLLEGE OF ENGINEERING DEPARTMENT OF COMPUTER SCIENCE & ENGINEERING ACADEMIC YEAR (ODD SEMESTER) QUESTION BANK
KINGS COLLEGE OF ENGINEERING DEPARTMENT OF COMPUTER SCIENCE & ENGINEERING ACADEMIC YEAR 2011 2012(ODD SEMESTER) QUESTION BANK SUBJECT CODE / NAME: IT1402-MIDDLEWARE TECHNOLOGIES YEAR/SEM : IV / VII UNIT
More informationLanguage support for AOP
Language support for AOP AspectJ and beyond Mario Südholt www.emn.fr/sudholt INRIA and École des Mines de Nantes OBASCO project, Nantes, France Language support for AOP ; Mario Südholt; INRIA/EMN; March
More informationDesigning Aspect-Oriented Crosscutting in UML
Designing Aspect-Oriented Crosscutting in UML Dominik Stein, Stefan Hanenberg, and Rainer Unland Institute for Computer Science University of Essen, Germany {dstein shanenbe unlandr}@cs.uni-essen.de ABSTRACT
More informationUnit-Testing Aspectual Behavior
Unit-Testing Aspectual Behavior [Position Paper] Cristina Videira Lopes and Trung Chi Ngo Donald Bren School of Information and Computer Sciences University of California, Irvine Irvine, CA 92697 {lopes,trungcn}@ics.uci.edu
More informationBEAWebLogic Server and WebLogic Express. Programming WebLogic JNDI
BEAWebLogic Server and WebLogic Express Programming WebLogic JNDI Version 10.0 Document Revised: March 30, 2007 Contents 1. Introduction and Roadmap Document Scope and Audience.............................................
More informationDesign patterns using Spring and Guice
Design patterns using Spring and Guice Dhanji R. Prasanna MANNING contents 1 Dependency 2 Time preface xv acknowledgments xvii about this book xix about the cover illustration xxii injection: what s all
More informationThe Koala Component Model for Consumer Electronics Software by: Ommering, Linden, Kramer, Magee. Presented by: Bridget Flaherty.
The Koala Component Model for Consumer Electronics Software by: Ommering, Linden, Kramer, Magee Presented by: Bridget Flaherty Koala Overview Motivation The Koala Model Handling Diversity Coping with Evolution
More informationReflective Java and A Reflective Component-Based Transaction Architecture
Reflective Java and A Reflective Component-Based Transaction Architecture Zhixue Wu APM Ltd., Poseidon House, Castle Park, Cambridge CB3 0RD UK +44 1223 568930 zhixue.wu@citrix.com ABSTRACT In this paper,
More informationSDC Design patterns GoF
SDC Design patterns GoF Design Patterns The design pattern concept can be viewed as an abstraction of imitating useful parts of other software products. The design pattern is a description of communicating
More informationAspect-Oriented Programming and Aspect-J
Aspect-Oriented Programming and Aspect-J TDDD05 Ola Leifer Most slides courtesy of Jens Gustafsson and Mikhail Chalabine Outline: Aspect-Oriented Programming New concepts introduced Crosscutting concern
More informationAspect Oriented Programming
1 Aspect Oriented Programming Programming Languages Seminar Presenter: Barış Aktemur University of Illinois 18 Feb. 2004 Mostly taken from Bedir Tekinerdogan s slides Outline Introduction Problems Terminology
More informationUniAspect: A Language-Independent Aspect-Oriented Programming Framework
UniAspect: A Language-Independent Aspect-Oriented Programming Framework Akira Ohashi Kazunori Sakamoto Tomoyuki Kamiya Reisha Humaira Satoshi Arai Hironori Washizaki Yoshiaki Fukazawa Waseda University
More informationApplication Servers in E-Commerce Applications
Application Servers in E-Commerce Applications Péter Mileff 1, Károly Nehéz 2 1 PhD student, 2 PhD, Department of Information Engineering, University of Miskolc Abstract Nowadays there is a growing demand
More informationAspect-Oriented Reconfigurable Middleware for Pervasive Systems
Aspect-Oriented Reconfigurable Middleware for Pervasive Systems Gustavo G. Pascual Departamento de Lenguajes y Ciencias de la Computación University of Málaga, Málaga (SPAIN) CAOSD group (http:/caosd.lcc.uma.es),
More informationN-Tiered Enterprise Styles. Example 1. Key Concepts. Component-Based Software Engineering. ECE493-Topic 4 Winter 2006
Component-Based Software Engineering ECE493-Topic 4 Winter 2006 Lecture 14 Enterprise Styles/Patterns (Part B) Ladan Tahvildari Assistant Professor Dept. of Elect. & Comp. Eng. University of Waterloo N-Tiered
More informationNAME (as it appears on your UF ID): (Please PRINT) CEN Software Engineering
NAME (as it appears on your UF ID): (Please PRINT) UF Student ID#: ------------------------------- CEN 5035 - Software Engineering ----------------------------- Exam 2 Fall 2010 You have 90 minutes to
More informationTransJ: An Abstract Independent-Framework for Weaving Crosscutting Concern into Distributed Transactions
Computer Technology and Application 7 (2016) 173-195 doi: 10.17265/1934-7332/2016.04.001 D DAVID PUBLISHING TransJ: An Abstract Independent-Framework for Weaving Crosscutting Concern into Distributed Transactions
More informationFast Track to Spring 3 and Spring MVC / Web Flow
Duration: 5 days Fast Track to Spring 3 and Spring MVC / Web Flow Description Spring is a lightweight Java framework for building enterprise applications. Its Core module allows you to manage the lifecycle
More informationObject-Oriented Design
Object-Oriented Design Lecturer: Raman Ramsin Lecture 20: GoF Design Patterns Creational 1 Software Patterns Software Patterns support reuse of software architecture and design. Patterns capture the static
More informationAppendix A - Glossary(of OO software term s)
Appendix A - Glossary(of OO software term s) Abstract Class A class that does not supply an implementation for its entire interface, and so consequently, cannot be instantiated. ActiveX Microsoft s component
More informationAPTE: Automated Pointcut Testing for AspectJ Programs
APTE: Automated Pointcut Testing for AspectJ Programs Prasanth Anbalagan Department of Computer Science North Carolina State University Raleigh, NC 27695 panbala@ncsu.edu Tao Xie Department of Computer
More informationMicrosoft MB Microsoft CRM Extending MS CRM 1.2 with.net.
Microsoft MB2-228 Microsoft CRM Extending MS CRM 1.2 with.net http://killexams.com/exam-detail/mb2-228 Answer: A, C QUESTION: 140 Which of the following statements are true for Microsoft CRM object dependencies?
More informationFlexiNet Matthew Faupel & Richard Hayton
(C) Ansa Consortium 1997 FlexiNet 1 1997 ANSA Consortium Matthew Faupel & Richard Hayton Utilising WWW increases Complexity Global Organisations - Electronic Commerce - Devolved Management Policy based
More informationEPL 603 TOPICS IN SOFTWARE ENGINEERING. Lab 6: Design Patterns
EPL 603 TOPICS IN SOFTWARE ENGINEERING Lab 6: Design Patterns Links to Design Pattern Material 1 http://www.oodesign.com/ http://www.vincehuston.org/dp/patterns_quiz.html Types of Design Patterns 2 Creational
More informationUsing Design Patterns in Java Application Development
Using Design Patterns in Java Application Development ExxonMobil Research & Engineering Co. Clinton, New Jersey Michael P. Redlich (908) 730-3416 michael.p.redlich@exxonmobil.com About Myself Degree B.S.
More informationSo, What is an Aspect?
Introduction to AspectJ Aspect-oriented paradigm AspectJ constructs Types of Join Points Primitive Lexical designators Type designators Control flow Types of Advice Before After Around Receptions Join
More informationDistribution and Integration Technologies
Distribution and Integration Technologies Distributed Architectures Patterns and Styles 1 Distributed applications infrastructure ISP intranet wireless backbone desktop computer: server: laptops: tablets:
More informationUnifying Software Reuse
Unifying Software Reuse Jörg Kienzle Software Composition and Reuse Laboratory (SCORE) School of Computer Science McGill University Montreal, Canada Email: Joerg.Kienzle@mcgill.ca 1 How Did We Get Here?
More informationUNIT I. 3. Write a short notes on process view of 4+1 architecture. 4. Why is object-oriented approach superior to procedural approach?
Department: Information Technology Questions Bank Class: B.E. (I.T) Prof. Bhujbal Dnyaneshwar K. Subject: Object Oriented Modeling & Design dnyanesh.bhujbal11@gmail.com ------------------------------------------------------------------------------------------------------------
More informationIDERA ER/Studio Software Architect Evaluation Guide. Version 16.5/2016+ Published February 2017
IDERA ER/Studio Software Architect Evaluation Guide Version 16.5/2016+ Published February 2017 2017 IDERA, Inc. All rights reserved. IDERA and the IDERA logo are trademarks or registered trademarks of
More informationAspect Oriented Java RMI Server
Aspect Oriented Java RMI Server Inderjit Singh Dhanoa BIS College of Engineering & Tech., Moga inderp10@yahoo.co.in Er.Dalwinder Singh Salaria Lovely Professional University ds_salaria@yahoo.co.in ABSTRACT
More informationSome language elements described in this text are not yet supported in the current JAsCo version (0.8.x). These are: Multiple hook constructors
!IMPORTANT! Some language elements described in this text are not yet supported in the current JAsCo version (0.8.x). These are: Multiple hook constructors Gotchas when migrating to 0.8.5 from an earlier
More informationAspect Oriented Programming
Aspect Oriented Programming Why, What and How? Andy Clement AspectJ Committer IBM Hursley Park clemas@uk.ibm.com 1 Agenda Why? Why do we need AOP? What? What is AOP? AspectJ How? The need for tool support
More informationIncorporating applications to a Service Oriented Architecture
Proceedings of the 5th WSEAS Int. Conf. on System Science and Simulation in Engineering, Tenerife, Canary Islands, Spain, December 16-18, 2006 401 Incorporating applications to a Service Oriented Architecture
More informationIngegneria del Software Corso di Laurea in Informatica per il Management. Design Patterns part 1
Ingegneria del Software Corso di Laurea in Informatica per il Management Design Patterns part 1 Davide Rossi Dipartimento di Informatica Università di Bologna Pattern Each pattern describes a problem which
More informationA Flexible Architecture for Pointcut-Advice Language Implementations
A Flexible Architecture for Pointcut-Advice Language Implementations Christoph Bockisch Mira Mezini Darmstadt University of Technology Hochschulstr. 10, 64289 Darmstadt, Germany {bockisch, mezini}@informatik.tu-darmstadt.de
More informationExplicitly distributed AOP using AWED
Explicitly distributed AOP using AWED ABSTRACT Luis Daniel Benavides Navarro, Mario Südholt OBASCO project École des Mines de Nantes/INRIA 4 rue Alfred Kastler 44307 Nantes cedex 3, France {lbenavid,sudholt}@emn.fr
More informationSummary of the course lectures
Summary of the course lectures 1 Components and Interfaces Components: Compile-time: Packages, Classes, Methods, Run-time: Objects, Invocations, Interfaces: What the client needs to know: Syntactic and
More informationDesign Patterns. Dr. Rania Khairy. Software Engineering and Development Tool
Design Patterns What are Design Patterns? What are Design Patterns? Why Patterns? Canonical Cataloging Other Design Patterns Books: Freeman, Eric and Elisabeth Freeman with Kathy Sierra and Bert Bates.
More informationAdding Dynamic Reconfiguration Support to JBoss AOP
Adding Dynamic Reconfiguration Support to JBoss AOP Nico Janssens, Eddy Truyen, Frans Sanen and Wouter Joosen DistriNet, Department of Computer Science, K.U.Leuven Celestijnenlaan 200A B-3001 Leuven, Belgium
More informationCSCD01 Engineering Large Software Systems. Design Patterns. Joe Bettridge. Winter With thanks to Anya Tafliovich
CSCD01 Engineering Large Software Systems Design Patterns Joe Bettridge Winter 2018 With thanks to Anya Tafliovich Design Patterns Design patterns take the problems consistently found in software, and
More informationThe Actor Role Coordinator Implementation Developer s Manual
The Actor Role Coordinator Implementation Developer s Manual Nianen Chen, Li Wang Computer Science Department Illinois Institute of Technology, Chicago, IL 60616, USA {nchen3, li}@iit.edu 1. Introduction
More informationNew Programming Paradigms
New Programming Paradigms Lecturer: Pánovics János (google the name for further details) Requirements: For signature: classroom work and a 15-minute presentation Exam: written exam (mainly concepts and
More informationWiZNet Integration of different Web service Registries
WiZNet Integration of different Web service Registries Technical University of Vienna Information Systems Institute Distributed Systems Group Schahram Dustdar and Martin Treiber dustdar@infosys.tuwien.ac.at
More informationEnterprise AOP With the Spring Framework
Enterprise AOP With the Spring Framework Jürgen Höller VP & Distinguished Engineer, Interface21 Agenda Spring Core Container Spring AOP Framework AOP in Spring 2.0 Example: Transaction Advice What's Coming
More informationLanguage-Independent Aspect-Oriented Programming
Language-Independent Aspect-Oriented Programming Donal Lafferty Donal.Lafferty@cs.tcd.ie Distributed Systems Group Department of Computer Science Trinity College Dublin Vinny Cahill Vinny.Cahill@cs.tcd.ie
More informationUsing Aspects to Make Adaptive Object-Models Adaptable
Using Aspects to Make Adaptive Object-Models Adaptable Ayla Dantas 1, Joseph Yoder 2, Paulo Borba 1, Ralph Johnson 2 1 Software Productivity Group Informatics Center Federal University of Pernambuco Recife,
More informationLisa Banks Distributed Systems Subcommittee
z/tpf V1.1 Title: Concepts of z/tpf SOAP Consumer Support Lisa Banks Distributed Systems Subcommittee AIM Enterprise Platform Software IBM z/transaction Processing Facility Enterprise Edition 1.1.0 Any
More informationUsing Aspects to Make Adaptive Object-Models Adaptable
Using Aspects to Make Adaptive Object-Models Adaptable Ayla Dantas 1, Joseph Yoder 2, Paulo Borba, and Ralph Johnson 1 Software Productivity Group Informatics Center Federal University of Pernambuco Recife,
More informationTrusted Components. Reuse, Contracts and Patterns. Prof. Dr. Bertrand Meyer Dr. Karine Arnout
1 Last update: 2 November 2004 Trusted Components Reuse, Contracts and Patterns Prof. Dr. Bertrand Meyer Dr. Karine Arnout 2 Lecture 5: Design patterns Agenda for today 3 Overview Benefits of patterns
More information