Features of AOP languages AOP languages have the following main elements: –a join point model (JPM) wrt base PL –a specification language for expressing.

Slides:



Advertisements
Similar presentations
Aspect Oriented Programming. AOP Contents 1 Overview 2 Terminology 3 The Problem 4 The Solution 4 Join point models 5 Implementation 6 Terminology Review.
Advertisements

1 JAC : Aspect Oriented Programming in Java An article review by Yuval Nir and Limor Lahiani.
Inheritance Inheritance Reserved word protected Reserved word super
Overview of AspectJ Aspect Oriented Software Development Seminar Technion presented by Oren Mishali.
University of British Columbia Software Practices Lab Fluid AOP Join Point Models Terry Hon Gregor Kiczales.
Road Map Introduction to object oriented programming. Classes
OOP in Java Nelson Padua-Perez Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
University of British Columbia Software Practices Lab CAS Seminar 06 Fluid AJ - A Simple Fluid AOP Tool Terry Hon Gregor Kiczales.
More on AspectJ. aspect MoveTracking { private static boolean _flag = false; public static boolean testAndClear() { boolean result = _flag; _flag = false;
Compilation 2007 Scopes and Environments Michael I. Schwartzbach BRICS, University of Aarhus.
Abstract Data Types and Encapsulation Concepts
1 An introduction to design patterns Based on material produced by John Vlissides and Douglas C. Schmidt.
AOP and Aspect C++ presentation by Igor Kotenkov based on presentation by Andreas Gal, Daniel Lohmann and Olaf Spinczyk.
Java Methods By J. W. Rider. Java Methods Modularity Declaring methods –Header, signature, prototype Static Void Local variables –this Return Reentrancy.
Comparison of OO Programming Languages © Jason Voegele, 2003.
Aspect Oriented Programming (AOP) in.NET Brent Krueger 12/20/13.
Master’s Thesis Defense: Aspectual Concepts John J. Sung.
1 Java Inheritance. 2 Inheritance On the surface, inheritance is a code re-use issue. –we can extend code that is already written in a manageable manner.
Polymorphism, Inheritance Pt. 1 COMP 401, Fall 2014 Lecture 7 9/9/2014.
Integrating Independent Components with On-Demand Remodularization based on OOPSLA 2002 paper by Mira Mezini Klaus Ostermann Prepared by Karl Lieberherr.
Extensible Plug-ins for Aspect-Oriented Programming Macneil Shonle*Ankit Shah.
Expression evaluation E : S | C. S = int. C = Op E E. Op : A | M. A = “+”. M = “*”.
Aspect Oriented Programming Sumathie Sundaresan CS590 :: Summer 2007 June 30, 2007.
Aspect Oriented Programming Gülşah KARADUMAN.
Slides for Gregor Kiczales Two versions –short version: Crosscutting capabilities for Java and AspectJ through DJ (4 viewgraphs only) –long version: Controlling.
A Meta-Level Specification and Profile for AspectJ in UML Joerg Evermann School of Information Management Victoria University of Wellington.
Chapter 14 Generics and the ArrayList Class Slides prepared by Rose Williams, Binghamton University Copyright © 2008 Pearson Addison-Wesley. All rights.
AOSD1 Aspect-Oriented Software Design Karl Lieberherr Theo Skotiniotis.
AOP-1 Aspect Oriented Programming. AOP-2 Aspects of AOP and Related Tools Limitation of OO Separation of Concerns Aspect Oriented programming AspectJ.
Data Structures Using C++ 2E1 Inheritance An “is-a” relationship –Example: “every employee is a person” Allows new class creation from existing classes.
Master’s Thesis Defense: Aspectual Concepts John J. Sung.
Object-Oriented Design CSC 212. Announcements This course is speeding up and we are starting new material. Please see me if you feel this is going too.
AOP Foundations Doug Orleans Karl Lieberherr. What we did earlier AOP languages have the following main elements: –a join point model (JPM) wrt base PL.
Adaptive Software Kevin Cella Graduate Seminar 02/04/2005.
© Siemens AG, CT SE 2 C O R P O R A T E T E C H N O L O G Y 1 Model-Driven Development for Pluggable Collaborations Iris Groher, Stephan Bleicher, Christa.
Inter-Type Declarations in AspectJ Awais Rashid Steffen Zschaler © Awais Rashid, Steffen Zschaler 2009.
AspectJ – AOP for Java Tom Janofsky. Instructor at Penn State Abington Consultant with Chariot Solutions JUG Member.
Course Progress Lecture 1 –Java data binding: Basket example: UML class diagram -> class dictionary without tokens-> language design -> class dictionary.
AOP issues. Class/Aspect Table Loose Coupling Classes/Aspects When we evolve a class, how many aspects do we have to change? When we evolve an aspect,
Software Engineering Laboratory, Department of Computer Science, Graduate School of Information Science and Technology, Osaka University IWPSE 2003 Program.
Demeter Aspects We study techniques for the emerging area of Aspect-Oriented Software Development and focus on the following areas:  Aspectual Collaborations.
Checking LoD in AspectJ Show the idea, not the details. How can we precisely express it in a programming language?
Chapter 8: Aspect Oriented Programming Omar Meqdadi SE 3860 Lecture 8 Department of Computer Science and Software Engineering University of Wisconsin-Platteville.
Translating Traversals to AspectJ. Outline Motivation Demeter Process for Traversals AspectJ Translation Process.
DJ: traversal-visitor-style programming in Java Josh Marshall/ Doug Orleans Want to add more on traversal through collections and Aspectual Components.
问题 Code scattering Blocks of duplicated code Blocks of complementary code, and different modules implementing complementary parts of the concern Code.
Comparison of Different AOP Approaches Presented by: Xiaojing Wang.
Classes, Interfaces and Packages
AOP/cross-cutting What is an aspect?. An aspect is a modular unit that cross-cuts other modular units. What means cross-cutting? Apply AOP to AOP. Tease.
CSC450 Software Engineering Devon M. Simmonds University of North Carolina, Wilmington 1.
3 Project Objectives Aspectual Collaborations (AC) for the Connection Aspect –Metric: Does the restructuring of the UAV code with AC reduce the tangling.
UBC software modularity group 1/14/02 UCSD1 Discussion with Kiczales at UBC Ontology of AOP Ontology is the study of what there is, an inventory of what.
COM1205 TraversalJ Project* Pengcheng Wu Feb.25,2003.
AOP with AspectJ Awais Rashid, Steffen Zschaler © Awais Rashid, Steffen Zschaler 2009.
AO Mechanisms in Demeter1 Discussion with Gregor Kiczales at UBC Ontology of AOP Ontology is the study of what there is, an inventory of what exists. An.
Talk only to your friends that share the same concerns (Law of Demeter for Concerns) Midterm Review February 2004.
Features of AOP languages AOP languages have the following main elements: –a join point model (JPM) wrt base PL –a specification language for expressing.
Crosscutting Capabilities for Java and AspectJ through DJ
Discussion with Gregor Kiczales at UBC
Demeter Aspects Who We Are Aspectual Collaborations
Aspect-Oriented Design and Patterns
Chapter 6 Methods: A Deeper Look
Java Programming Language
Better Separation of Crosscutting Concerns with Aspectual Components
Requirements for better object-oriented design and programming languages Could be organized better.
AOSD and the Law of Demeter: Shyness in Programming
AspectAda Aspect-Oriented Programming for Ada95
Refactoring the Aspectizable Interfaces: An Empirical Assessment
Presentation transcript:

Features of AOP languages AOP languages have the following main elements: –a join point model (JPM) wrt base PL –a specification language for expressing sets of join points (JPS) –a means of specifying behavior involving join points (BJP) –encapsulated units combining JPS and BJP (CSB) –method of attachment of units to base program (AU)

Features of AOP languages AOP languages have the following main elements: –a join point model (JPM) wrt base PL –a specification language for expressing sets of join points (JPS) –a means of specifying behavior involving join points (BJP) –encapsulated units combining JPS and BJP (CSB) –method of attachment of units to base program (AU) JPS and BJP are sometimes overlapping. JPS might already define an initial behavior plus a set of join points in that behavior.

Comparing AspectJ DemeterJ DJ ATC AspectC Aspectual Collaborations D (COOL, RIDL) BETA RG

AspectJ from Xerox PARC

AspectJ JPM principled points of execution –message sends (basically a method call), message receptions, method executions –field references (get and set) –exception throwing and handling –constructor execution which context is available at each join point?

AspectJ JPS pointcut designators –primitive: calls(sig), receptions(sig), executions(sig), instanceof(type), within(type), cflow(pcd), getter(sig?), setter(sig?) –operators: &&, ||, ! can name a pointcut and expose context –pointcut foo (V v):pcd (using v); pointcut maybe abstract (declaration) and defined in a subaspect.

AspectJ BJP before, after, around: a pointcut. can refer to thisJoinPoint –explain join point object: instance of JoinPoint class. Interface: getSignature(), getActualParameters(),… JoinPoint has eleven subclasses: CallJoinPoint, ReceptionJoinPoint, ExecutionJoinPoint, ExceptionJoinPoint, … in around (instead of) can say: proceed()

AspectJ CSB an aspect contains a list of advice and point cut declarations and introductions and regular fields and methods.

Explaining aspect instance when you declare an aspect, you say either of eachJVM() or of eachobject(pcd) logging: log stream put in aspect instance of each VM (one instance for whole program) dft: mark field put it in aspect instance of each object (node object of the graph)

AspectJ AU ajc takes a list of files: aspects and classes and weaves them together.

DemeterJ From Northeastern

DemeterJ JPM traversal method calls on Java object, constructor calls

DemeterJ JPS strategies –define family of traversal programs to be enhanced –approximation: function mapping object graphs to subgraphs –are enhanced by visitors sentences –define family of Java objects: executions of constructor calls –are not further enhanced

DemeterJ BJP visitor classes –before *

DemeterJ CSB adaptive methods –void f() to S (V1, V2)

DemeterJ AU make new.beh file, add to.prj file, demeterj

DJ Java library from Northeastern Present two views of DJ as an AOP system Two views –object graphs as join points –object graph slices as join points

DJ JPM object graph : nodes and edges principled points: traversal of nodes or edges fix a traversal algorithm

DJ JPS strategies –define family of traversal programs to be enhanced –approximation: function mapping object graphs to subgraphs (object graph slices)

DJ BJP visitor classes –before(A a), after(C c), cbefore_x(Object a, Object b), caround_x(Object a, Object b, Subtraverser st) –each method applies to a different part of the point cut (strategy)

DJ CSB aspectual methods void f(ClassGraph cg) { cg.traverse(this, “from A to S”, new Visitor() {…});}

DJ AU add methods to classes

DJ: Second view: Doug Doug Orleans

DJ JPM object graph slices: nodes and edges fix a traversal algorithm

DJ JPS strategies –define family of traversal programs to be enhanced –approximation: function mapping object graphs to subgraphs (object graph slices) in addition: visitor methods are pointcut designators pointcut designators are encoded in signatures of visitor methods

DJ BJP visitor classes –each visitor method is advice on the point cut specified by the method signature

DJ CSB a visitor class is a package of advice when you use a visitor in a traversal of an ogs (in traverse) then each pointcut is intersected with the traversal pointcut, namely cflow(traverse). (can also use within)

DJ AU to attach an aspect you call traverse with an aspect (visitor). traverse expression attaches the aspect to an object graph slice.

AspectC From the University of BC

AspectC JPM function calls, variable references data available: args to function calls

AspectC JPS point cut designators –call (foo( c )): all calls of function foo with one argument –cflow( any point cut designator): “whatever comes afterwards on the stack” –varref(name) –combine with &&, || and !

AspectC BJP before, after, around

AspectC CSB are hardwired together: when advice is given, you need to give point cut

AspectC AU concatenated to the source

ATC From Doug Orleans at Northeastern

ATC JPM Aspects in Tiny CLOS generic function receptions, method executions use MOP to implement aspects what data is exported: see join point object

ATC JPS ! point cut designators –predicate on aspect instance and join point object –explain join point object: instance of class. Interface: slots: generic (generic function being called), args (actual parameters), stack (stack of join points in current control flow) has two subclasses: and has additional slot: method (being executed) (all the traversal methods in the cflow of the first traversal call)

ATC BJP before, after, around: take aspect instance and join point object as argument. around has third arg: continuation generic function...

ATC CSB advice has a pointcut generic function (like an abstract pointcut in AspectJ). Methods of generic function are specified separately. an aspect contains a list of advice (no point cut declaration) an aspect is an instance of

Explaining aspect instance class has two subclasses: logging: log stream put in aspect instance of each VM (one instance for whole program) dft: mark field put it in aspect instance of each object (node object of the graph)

ATC AU ! mixin: has slot aspects: holds list of attached aspects is a subclass of both and ( is the class of all generic functions) add-aspect!, remove-aspect! all generic functions in base program are aspectizable (non-obliviousness ok)

Aspectual Collabs From NU

join point model allows for parameterization; join point patterns and their instances.

Aspectual Collaborations JPM principled points of execution ? –abstract join points that are mapped by the adapter to concrete ones –execution of methods modified by collaboration enhance the class graph: open classes: add more members to existing classes which context is available at each join point?

Aspectual Collaborations JPM syntactic methods and fields, not points of execution Replacement allows us to capture execution Two kinds of method capture –tradeoff between access to arguments/result vs. generality

Aspectual Collaborations JPS sets of join points: collaboration + adapter (in the adapters we express the cross cutting) collaboration roles only: have the flavor of an abstract pointcut. adapter specifies links between methods and fields requirements can be exported unfulfilled. future version: globbing with guard operators

Aspectual Collaborations BJP before, after, around: for methods can refer to actual parameters in replace (around (instead of)) can say: expected() Depending on which join point model: can access/modify arguments or cannot.

Aspectual Collaborations CSB collaborations and adapters Each adapter is processed to generate a new collaboration. Collaborations can encapsulate some behavior and export other.

AC instances Complicated sharing model ?

Aspectual Collaborations AU ac-compiler (non existent) takes a list of files: classes and collaborations and adapters and weaves them together. Weaving is incremental. Compilation is external to weaving. Process is finished when no more requirements remain.

Using AspectJ to implement collaborations/adapters AspectJ can only express the adapted collaborations ? It has abstract pointcuts. AspectJ supports interfaces with full methods and multiple inheritance

Goal Input: classes, collaborations, adapters Output: AspectJ code

D From Northeastern, continued at Xerox PARC

D From Crista’s thesis and implemented in DemeterJ –COOL –RIDL concern specific aspect language

COOL JPM principled points of execution –method calls which context is available at each join point? Can look at objects, but not modify them.

COOL JPS sets of join points: exclusion sets exclusion sets do more than defining a set of join points: initial behavior of coodination enhanced by method managers

COOL BJP method managers

COOL CSB coordinators

COOL AU demeterj: takes coordinators (in.cool files) and.cd.beh and.ridl files and weaves them together.

RIDL JPM principled points of execution –method calls and object graphs of parameters and return types which context is available at each join point? Parameters and return values are processed according to transfer specs.

RIDL JPS sets of join points: for parameters and return types: transfer specifications in portals specify them. Only initial behavior is of interest: selecting an object graph slice. Portals list the methods

RIDL BJP transfer specifications modify behavior of methods. transfer specs are themselves aspects. Two layers. Similar to AP.

RIDL CSB portals

RIDL AU demeterj: takes portals (in.ridl files) and.cd.beh and.cool files and weaves them together.

BETA from the Beta community (Aarhus, etc.) The BETA fragment system: syntax directed program modularization (1983 paper)

BETA JPM join points –slots: designated positions in the source code –class Leg { > …} -can weave new declarations into the join point which context is available at each join point? refer to what is in scope of slot.

BETA JPS pointcut designators –have to explicitly write a set of slots into the base code or the fragments one slot name = one pointcut

BETA BJP? This code goes into this slot.

BETA CSB Fragment binding process: binding of fragments to slots –fragment groups (named collection of fragments contributing to the implementation of an aspect) –fragment group attributes (origin, include, body): references from one group to another origin: required (except for basic fragment group); origin chain reached by traversal.

Fragment Graph f1 s1 f2

BETA CSB a fragment group contains a list of slots embedded in code

BETA AU Through fragment system organization. Use of include: include dingbats and Color. static

BETA need to define the slots where code can be inserted. No predefined join points. Good at composition of fragments. Fragments may have their own slots. Base program is not oblivious about aspects. But could have predefined join points.

BETA A fragment group is a modular unit of cross cutting implementation. It is an aspect.

RG memoization aspect compiler related aspects, operate on join points (message sends in the static call graph) –fusion aspect –memory management aspect modify behavior of compiler: fancy pragma transformation: almost not AOP could not be done in AspectJ ?

What is an aspect? An aspect turns a tangled and scattered implementation of a concern into a well- modularized implementation of a concern. An aspect is a modular unit of cross cutting implementation.