Comments on: Aspects https://quoderat.megginson.com/2005/07/29/aspects/ Open information and technology. Thu, 04 Aug 2005 11:10:06 +0000 hourly 1 http://wordpress.com/ By: Juri Memmert https://quoderat.megginson.com/2005/07/29/aspects/#comment-252 Thu, 04 Aug 2005 11:10:06 +0000 http://www.megginson.com/blogs/quoderat/?p=57#comment-252 I have been using AOSD concepts and tools for several years now in my work as a consultant and I find them incredibly useful.
That said, I find the AspectJ school-of-thought and approach to be completely over-hyped. Most people who advocate it do not know how a commercial project works and those who do seem to have vastly different projects than I have had in the last 7 years… so different that I have a hard time recognizing them as the same thing.

Conceptually, AOSD, not AOP or AspectJ, is a great approach, but the currently available tools, of which AspectJ is the most prominent one, do fail in a variety of places. I actually wrote a blog entry about that, but this is no plug to do some self-advertisement (http://www.jpmdesign.net/wordpress/2005/08/04/aspectj-where-to-improve/).
If you intend to look at AOSD and wonder whether it’s worth it, I can only suggest looking at the AOSD mailing list (at aosd.net) and skip all the “I don’t know how to do this in AspectJ” questions which should never have been posted to that list anyway.

As for the comment from Brendan McKenna: “To my mind, it’d be a lot easier to ’sell’ to people if it would use the normal Java syntax for classes, instead of the ‘aspect’ stuff, and some supplementary syntax (which they have) to describe how to apply the overridden methods to those in the base class (the before/after/around stuff).”

AspectJ is using this kind of language extensions and they have been criticized for it. Other AOSD approaches (Hyper/J, CME) do not do that and offer support beyond the mere code level (Concern Models, like Cosmos).

As for the comment by Russ Miles: “But aren’t use cases another form of cross-cutting concern? When you start to think about your software’s architecture in those terms you can start to really apply AOP in a more general fashion and, in my experience so far, that’s where the design really starts to benefit.”

Yes, you are correct. And AspectJ fails in this area. Concern models do provide some support here as do some approaches to bring AOSD to the architectural languages (can’t find the reference just now… It was at the last AOSD). Unless AOSD tool support truly supports all phases of the development, it will die off as a quirk.

]]>
By: Brendan McKenna https://quoderat.megginson.com/2005/07/29/aspects/#comment-251 Thu, 04 Aug 2005 09:54:42 +0000 http://www.megginson.com/blogs/quoderat/?p=57#comment-251 I’ve looked at AOP a fair amount and have used it in a couple of proof-of-concept projects (I’ve used AspectJ). Aside from the additional compile errors and warnings that it allows you to define, most of what AOP seems to be providing is a (somewhat sneaky) means to introduce multiple inheritance. To my mind, it’d be a lot easier to ‘sell’ to people if it would use the normal Java syntax for classes, instead of the ‘aspect’ stuff, and some supplementary syntax (which they have) to describe how to apply the overridden methods to those in the base class (the before/after/around stuff). Large parts of AOP remind me of CLOS more than anything else….

I mean, most of what an aspect is is another base class that the advised classes are inheriting behaviour and/or attributes from, in addition to the one that Java allows them to.

]]>
By: Russ Miles https://quoderat.megginson.com/2005/07/29/aspects/#comment-250 Mon, 01 Aug 2005 17:16:11 +0000 http://www.megginson.com/blogs/quoderat/?p=57#comment-250 I totally agree that AOP adoption has been pretty conservative (to say the least :). But I’ve also found that the biggest problem seems to be that AOP is seen as dealing with a specific set of cross-cutting concerns only (that would be the logging/security/caching type of group).

But aren’t use cases another form of cross-cutting concern? When you start to think about your software’s architecture in those terms you can start to really apply AOP in a more general fashion and, in my experience so far, that’s where the design really starts to benefit.

]]>
By: Tim Howland https://quoderat.megginson.com/2005/07/29/aspects/#comment-249 Mon, 01 Aug 2005 13:32:17 +0000 http://www.megginson.com/blogs/quoderat/?p=57#comment-249 There seem to be two schools of AOP implementation- The compile-time version relies on pre-processing your source code to include the appropriate methods. The run-time version (Spring is the one I’ve looked at) uses proxy objects as wrappers around your classes and methods.

The compile-time version does seem to me like CPP macros; on the other hand, you can be sure that you won’t get huge variations after you’ve passed your unit testing. The run-time version seems cleaner, but seems like it has the potential to introduce changes in your application’s behavior at runtime, once it’s out in the wild.

I buy a lot of the argument that it makes sense for cross-application concerns, but I don’t know how many concerns there really are: Logging, Security, and possibly performance monitoring seem to be about it. Anything else seems not to be global enough to be worth the trouble.

Perhaps that’s why aren’t complaining about it so much? Maybe everyone is being awfully conservative with rolling it out…

]]>
By: Russ Miles https://quoderat.megginson.com/2005/07/29/aspects/#comment-248 Sat, 30 Jul 2005 13:39:36 +0000 http://www.megginson.com/blogs/quoderat/?p=57#comment-248 I’ve been advocating the *careful* use of AOP for a few years now. I’ve even written a book on the subject, see http://www.aspectjcookbook.com. In my opinion, aspects offer a fantastic way of enabling even higher degrees of loose coupling within your applications. Lets face it, the tighter coupled your software’s components are, the harder things are to change. Carefully designed aspects can actually offer a more natural representation of your users requirements (see AOP and use case book from Ivar Jacobson) and I’ve found that this affects the very architecture of my software; far from the regular “Aspects do logging/tracing/security” hello world examples that you’ll find all over the place.

A quick word of warning though. Aspects are powerful (particularly in heavyweight AOP implementations such as AspectJ), but with that power comes responsibility (doesn’t it always). A badly design AOP solution is no better than a badly designed OO solution; in fact it can be even worse.

]]>
By: Anonymous https://quoderat.megginson.com/2005/07/29/aspects/#comment-247 Fri, 29 Jul 2005 19:29:21 +0000 http://www.megginson.com/blogs/quoderat/?p=57#comment-247 via David Megginson | Aspect-Oriented Programming: Believe the hype?

Quoderat � Aspects In a recent post David Megginson writes: I’ve decided it’s time to figure out if aspect-oriented programming is worth, well, figuring out. A group of us which includes Russ Miles, the resident AOP expert within x2x2x.org, have…

]]>
By: Kris Johnson https://quoderat.megginson.com/2005/07/29/aspects/#comment-246 Fri, 29 Jul 2005 15:03:29 +0000 http://www.megginson.com/blogs/quoderat/?p=57#comment-246 I think my take on AOP is exactly like yours. If you get any responses through channels other than blog comments, or find other sources of information, please share them.

]]>