1 / 22

Software-Engineering II

Software-Engineering II. Aspektorientierung. Themenübersicht. Objektorientierung Aspektorientierung Vorgehensmodelle UML Analyse- & Entwurfsmuster Objektorientiertes Testen Versionsverwaltung Refactoring Labor (Praktischer Teil). Projektdokumentation:

tessa
Télécharger la présentation

Software-Engineering II

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Software-Engineering II Aspektorientierung

  2. Themenübersicht Objektorientierung Aspektorientierung Vorgehensmodelle UML Analyse- & Entwurfsmuster Objektorientiertes Testen Versionsverwaltung Refactoring Labor (Praktischer Teil)

  3. Projektdokumentation: http://www.eclipse.org/aspectj/doc/released/progguide/ Aspektorientierung

  4. Programmierparadigma (Prinzip) Erweiterung der herkömmlichen (objektorientierten) Programmierung Hilft dabei, Anwendungen strukturierter aufzubauen Aspektorientierung

  5. Man kann die generellen Aufgaben, die Applikationen erfüllen müssen in zwei bereiche Aufteilen Core-Level-Concerns:Erfüllen die funktionalen Anforderungen der Software (Berechnungen, …) System-Level-Concers: Erfüllen die technischen Randbedingungen der Software (Logging, …) Diese zwei Ebenen sind in Software-Systemen fast immer sehr eng verwoben „Cross-Cutting-Concerns“ Bei der Programmierung sollte es stets das Ziel sein, Methoden möglichst einfach und für einen dedizierten Zweck zu schreiben Vermeidung von Cross-Cutting-Concerns Grundproblem

  6. Durch die Definition eines Aspektes ist es möglich, Code bei bestimmten Ereignissen auszuführen Beispiel: Immer vor dem Ausführen der Methode „setName“ soll ein Text auf der Kommandozeile ausgegeben werden Mimimierung der Vermischung von System-Level-Concerns und Core-Level-Concerns in Methoden Die Idee des Aspekts

  7. Applikation führt Datenbank-Abfragen aus Alle SQL-Queries müssen vor und nach dem Ausführen in ein Log-File eingetragen werden => Fehleranalyse und Benchmarking Beispiel: SQL-Statement void execute( String query ) { Logger.Log( “START DB-Query @“ + new Date() + “: “ + query ); myDBMS.connect(…); myDBMS.execute(query); myDBMS.disconnect(…); Logger.Log( “END DB-Query @“ + new Date() + “: “ + query ); } System-Level-Concerns ====8<====8<====8<====8<====8<====8<====8<====8<====8<====8<====8<====8<==== START DB-Query @Mon Jan 01 12:00:00 CEST 2007: SELECT `password` FROM `user` WHERE `status` = ‘secret‘; END DB-Query @Mon Jan 01 12:00:01 CEST 2007: SELECT `password` FROM `user` WHERE `status` = ‘secret‘; START DB-Query @Mon Jan 01 12:00:01 CEST 2007: UPDATE `user` SET `password` = ‘hijacked‘; END DB-Query @Mon Jan 01 12:00:29 CEST 2007: UPDATE `user` SET `password` = ‘hijacked‘; ====8<====8<====8<====8<====8<====8<====8<====8<====8<====8<====8<====8<====

  8. Für Java: AspectJ Java hat Aspekte nicht als Feature in die Programmiersprache implementiert => Keine native Unterstützung Durch sogenanntes „weaving“ wird der Aspekt-Code in die Class-Dateien, die durch die Aspekte betroffen sind, eingesetzt („eingewoben“) AspectJ führt dies beim Compilieren der Code-Dateien durch Werkzeuge

  9. AOP-Library: http://www.eclipse.org/aspectj/ Mit Eclipse-Integration: http://www.eclipse.org/ajdt/ Download • Voraussetzung: Passende Version von Eclipse mit PDE • (Plugin Development Environment) • -> http://www.eclipse.org/

  10. Neues AspectJ-Projekt

  11. Neue Klasse sayHello-Methode Console-Output

  12. Aspekt anlegen I Neuen Aspekt anlegen

  13. Aspekt anlegen II Aspekt- definition

  14. [advice]: call( [return] [class].[method]([signature]) { [action] } [advice]: Definiert den Zeitpunkt der Überwachung before(): Vor dem Methodenaufruf after(): Nach dem Methodenaufruf (unabh. vom Ausgang) after() throwing: Wenn die Methode mit einer Exception geendet ist after() returning: Wenn die Methode regulär beendet wurde [return]: Der Rückgabetyp der Methode, auf den der Aspekt angewandt werden soll [class]: Der Name der Klasse, deren Methoden überwacht werden sollen [method]: Der Name der Methode der zu überwachenden Methode [signature]: Die Methodensignatur der zu überwachenden Methode [action]: Java-Code, der im Eventfall ausgeführt werden soll Im Bsp.: before():call( void HelloStudent.sayHello()){ System.out.println( "=== Saying hello ===" ); } Methodenaufruf überwachen

  15. [advice]: call( [return] [class].[method]([signature]) { [action] } Es ist an den meisten Stellen einer Aspekt-Definition erlaubt Wildcards (mit * gekennzeichnet) an Stelle von konkreten Angaben zu verwenden before(): call( * *.*() ) { System.out.println( "=== Calling any method ===" ); } Auch partielle Wildcards sind erlaubt: before(): call( * Hello*.say*() ) { System.out.println( "=== Calling a special method ===" ); } Wildcards für die Methodensignatur: “..“ before(): call( * Hello*.say*( .. ) ) { System.out.println( "=== Calling a special method with any parameters ===" ); } Wildcards

  16. Werden der konkrete und der Wildcard-Aspekt zusammen auf das Beispiel angewandt, ergibt sich folgendes Ergebnis: Angewandt before(): call( void HelloStudent.sayHello() ) { System.out.println( "=== Saying hello ===" ); } before(): call( * *.*() ) { System.out.println( "=== Calling any method ===" ); } === Saying hello === === Calling any method === Hello Student.

  17. Um sich die eventuell öfters wiederkehrende Filter-Defintionen sparen zu können, wurden Pointcuts eingeführt Ein Pointcut spezifiert eine Filter-Definition (auch Join Point genannt) wie sie schon zuvor verwendet wurden pointcut specialMethod(): call( void HelloStudent.sayHello() ); Dieses Pointcut kann dann durch ein advice angewandt werden: before(): specialMethod() { System.out.println( "=== Saying hello ===" ); } Pointcuts

  18. Für viele Anwendungen ist es sicherlich relevant, welche Parameter bei dem Methodenaufruf übergeben wurden Dies lässt sich über die Primitive args herausfinden Parameter pointcut benotung( float note ): call( void DHStudent.setNote( float ) ) && args( note ); Die Primitive args fängt dabei die Methoden-Argumente ab und speichert sie in der definierten Variable note. Diese muss sowohl in den Klammern von args(…) als auch in der Bezeichnung des Pointcut definiert sein. Angewandt werden kann dieses Pointcut folgendermaßen: after( floatnote ) returning: benotung( note ) { System.out.println("Benotet " + note); }

  19. So wie es möglich ist, die Parameter des Aufrufs zu erlangen, ist es auch möglich, herauszufinden, auf welches Objekt der Methodenaufruf stattfand Das aufgerufene Objekt pointcut benotung( DHStudent student ): call( void DHStudent.setNote( float ) ) && target( student ); Wie bei den Parametern kann später auf die Instanz von DHStudent zugegriffen werden: after( DHStudentstudent ) returning: benotung( student ) { System.out.println( "Student " + student + " wurde benotet." ); }

  20. @Annotation-Based • Alternativ ist es möglich, Aspekte in herkömmlichen Java-Klassen mithilfe von Annotations zu definieren • Pointcut-Definition steht im Annotation-Value • Dabei sollte man Annotations in separaten Packages halten @Aspect public class StudentAspect { @Before("call(void DHStudent.setNote(float)) && target(student)") public void beforeSetNote(DHStudent student) { System.out.println("Student " + student + " wurde benotet. "); } }

  21. Anwendung im BA-Umfeld publicaspect Benotung { pointcut benotung( DHStudent student, float note ): call( void DHStudent.setNote( float ) ) && args( note ) && target( student ); after( DHStudent student, float note ) returning: benotung( student, note ) { Studiengangsleiter.getInstance().NotifyBenotung( student, note ); } } Beachte: Ohne das Ändern des Codes von BADozent oder BAStudent war es möglich, den Studiengangsleiter über eine Notengebung zu informieren!

  22. Anwendung im BA-Umfeld publicaspect Benotung { pointcut benotung( DHStudent student, float note ): call( void DHStudent.setNote( float ) ) && args( note ) && target( student ); after( DHStudent student, float note ) returning: benotung( student, note ) { Studiengangsleiter.getInstance().NotifyBenotung( student, note ); } } publicclass Studiengangsleiter { privatestatic Studiengangsleiter sl = null; publicstatic Studiengangsleiter getInstance() { if( Studiengangsleiter.sl == null ) { Studiengangsleiter.sl = new Studiengangsleiter(); } return Studiengangsleiter.sl; } publicvoid NotifyBenotung( DHStudent student, float note ) { System.out.println( "Habe Note " + note + " für Student " + student + " notiert." ); } } Singleton Design-Pattern

More Related