Beefy Boxes and Bandwidth Generously Provided by pair Networks
Just another Perl shrine
 
PerlMonks  

Orcish Maneuver

by AidanLee (Chaplain)
on Dec 06, 2001 at 22:42 UTC ( [id://130021]=note: print w/replies, xml ) Need Help??


in reply to Re: (jcwren) Re: My code and your stupidity don't mix!
in thread Would you use 'goto' here?

What, if you would enlighten me, is an Orcish Maneuver? There are only mentions of it by name on the site, but no examples...

Replies are listed 'Best First'.
(Ovid) Re: Orcish Maneuver
by Ovid (Cardinal) on Dec 06, 2001 at 23:16 UTC

    The Orcish Maneuver is a term coined by Joseph Hall in his book "Effective Perl Programming" (co-authored by merlyn). Here's the essence of it:

    my @sorted = sort { ( $times{$a} ||= -M $a ) <=> ( $times{$b} ||= -M $b ) } @old_array;

    The "orcish" (a bad attempt at humor: "or cache") maneuver basically caches the results of an expensive lookup using the ||= operator. This operator says, in the above code, that $times{$a} will be evaluated or, if it is false, set it to the value of -M $a. (-M is the file test operator for last modified time). This allows you to cache the results of -M rather than call it every time. This has the same effect as:

    for ( @old_array ) { $times{ $_ } = -M $_; } my @sorted = sort { $times{$a} <=> $times{$b} } @old_array;

    Cheers,
    Ovid

    Join the Perlmonks Setiathome Group or just click on the the link and check out our stats.

Re: Orcish Maneuver
by dragonchild (Archbishop) on Dec 07, 2001 at 00:58 UTC
    My point exactly.

    ------
    We are the carpenters and bricklayers of the Information Age.

    Don't go borrowing trouble. For programmers, this means Worry only about what you need to implement.

Log In?
Username:
Password:

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

How do I use this?Last hourOther CB clients
Other Users?
Others having an uproarious good time at the Monastery: (3)
As of 2024-04-19 19:00 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found