Beefy Boxes and Bandwidth Generously Provided by pair Networks
laziness, impatience, and hubris
 
PerlMonks  

Re: Open to debate on mixins and traits.

by adrianh (Chancellor)
on Jun 02, 2004 at 18:21 UTC ( [id://359625]=note: print w/replies, xml ) Need Help??


in reply to Open to debate on mixins and traits.

Providing this type of behaviour for your own classes can be done in 4 ways.

Shall we say that there are at least four ways :-)

Aspect Oriented Programming is an obvious fifth direction that some people are taking. Creating a new language that incorporated the cross-cutting concern (in AOP speak) as part of the core language would be a sixth. Sticking the common behaviour in a meta-class in those languages that support them would be a seventh.

Any more for any more?

Replies are listed 'Best First'.
Re: Re: Open to debate on mixins and traits.
by BrowserUk (Patriarch) on Jun 02, 2004 at 19:25 UTC

    <generic cop-out>I was kind of limiting my thoughts to Perl:) </generic cop-out>

    Aspect Oriented Programming is an obvious fifth direction that some people are taking.

    That said, from my limited (and hastily reviewed), understanding of AOP, it isn't an means of implementation (be done), it's a ... um ... philosophy.

    It doesn't even have to involve objects (their claim). It basically says that the logical architecture doesn't have to be either a single-rooted tree nor a multi-root tree, it can be a graph. Which, as far as my math goes means that you can stick things in anywhere and cross-connect them however you like.

    There is (are?) concrete implementation(s) of AOP (Aspectj and ?). I don't know how they are implemented, but I suspect that it basically comes down to essentially the same as mixins/traits in that extra methods get attached directly or indirectly to the vtable.

    The difference is the logical view rather than the physical implementation. The basic goals are the same as mixins: The separation and re-use of common functionality without imposing super-dependant structure on the logical view of the system.

    Creating a new language that incorporated the cross-cutting concern (in AOP speak) as part of the core language would be a sixth.

    Isn't that exactly what the :trait notation of P6 is doing?

    Sticking the common behaviour in a meta-class in those languages that support them would be a seventh.

    I think that I would view this as the same as my second option; "Built-in to the base (universal) Object class", if the meta-class is the base meta-class.

    If your not proposing sticking the common behaviour in the base meta-class, but into meta-classes for each of your real classes, then all you've done is move the goal posts. You would still end up with cut&paste re-use, or one of the four options.


    Examine what is said, not who speaks.
    "Efficiency is intelligent laziness." -David Dunham
    "Think for yourself!" - Abigail

      I was kind of limiting my thoughts to Perl:)
      What about Aspect?

      There is (are?) concrete implementation(s) of AOP (Aspectj and ?). I don't know how they are implemented, but I suspect that it basically comes down to essentially the same as mixins/traits in that extra methods get attached directly or indirectly to the vtable.

      My (also limited) understanding of AOP is that it is not really just for object composition (as mix-ins/traits are), and therefore not directly related to OOP (although you rarely see AOP without OOP).

      As far as AOP implementation, it actually looks to me like Aspect is full of symbol-table madness, while AspectJ has an Aspect weaver which is essentially a compiler pre-processor.

      Creating a new language that incorporated the cross-cutting concern (in AOP speak) as part of the core language would be a sixth.
      Isn't that exactly what the :trait notation of P6 is doing?
      Similar, but not exactly. But again, my understanding of both is limited, but I don't see them as being exactly the same.

      -stvn

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://359625]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others browsing the Monastery: (4)
As of 2024-03-19 07:01 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found