Beefy Boxes and Bandwidth Generously Provided by pair Networks
good chemistry is complicated,
and a little bit messy -LW

Re: Recap: The Future of Perl 5 (class)

by Arunbear (Prior)
on Sep 03, 2018 at 10:58 UTC ( #1221615=note: print w/replies, xml ) Need Help??

in reply to Recap: The Future of Perl 5

Re the OO part - there are a few problems with the class idea. Firstly, how do class and package relate? Are they synonymous? Can you have one inside the other?

On a somewhat higher level, what if the class construct isn't the best way to do OOP.

Some newer languages (Go and Rust) have avoided having a class construct (but still support some flavour of OOP).

And going back much further, we find works like the GOF book, which was based around two principles

  • Program to an 'interface', not an 'implementation'
  • Favor 'object composition' over 'class inheritance'
So instead of just copying a sub-optimal construct that some other languages copied from others, maybe we ought to step back and look for better abstractions?

My own lengthy contemplation has led to a prototype of what such abstractions could look like. Mic provides Interfaces (which support Eiffel-like contracts) as a primary abstraction, and Implementations as a secondary abstraction.

I worry that what gets implemented would be "weaker" than what can already be achieved using libraries.
  • Comment on Re: Recap: The Future of Perl 5 (class)

Log In?

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

How do I use this? | Other CB clients
Other Users?
Others chilling in the Monastery: (3)
As of 2022-01-21 21:50 GMT
Find Nodes?
    Voting Booth?
    In 2022, my preferred method to securely store passwords is:

    Results (59 votes). Check out past polls.