Beefy Boxes and Bandwidth Generously Provided by pair Networks
Perl: the Markov chain saw
 
PerlMonks  

Re: Re: Subroutines: Returning a hash vs. hash reference

by mt2k (Hermit)
on Nov 28, 2002 at 04:50 UTC ( #216240=note: print w/replies, xml ) Need Help??


in reply to Re: Subroutines: Returning a hash vs. hash reference
in thread Subroutines: Returning a hash vs. hash reference

/me mutters something along the lines of "Why didn't I think of that?" :)

Anyhow, I went as far as 2000x2000 and got the following results:

return hash takes: 32 secs return hash REF takes: 11 secs
This demonstrates that hash REFs do indeed run much faster. I suppose that returning a regular hash requires that the interpreter copy the data structure... likely doubling the memory required to keep the data structure memorized.

Thanks a lot, I do believe I have got an answer to my "problem".

Replies are listed 'Best First'.
Re: Re: Re: Subroutines: Returning a hash vs. hash reference
by BrowserUk (Patriarch) on Nov 28, 2002 at 04:56 UTC

    It's actually worse than just copying the data structure...it first flattens the structure to a list of (key0, value0, key1, value1,...) then has to re-construct the hash by re-hashing all the keys. Its the latter part that takes most of the time.


    Okay you lot, get your wings on the left, halos on the right. It's one size fits all, and "No!", you can't have a different color.
    Pick up your cloud down the end and "Yes" if you get allocated a grey one they are a bit damp under foot, but someone has to get them.
    Get used to the wings fast cos its an 8 hour day...unless the Govenor calls for a cyclone or hurricane, in which case 16 hour shifts are mandatory.
    Just be grateful that you arrived just as the tornado season finished. Them buggers are real work.

Log In?
Username:
Password:

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

How do I use this? | Other CB clients
Other Users?
Others chilling in the Monastery: (5)
As of 2022-08-10 14:49 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found

    Notices?