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

Re^2: the basic datatypes, three

by Thilosophy (Curate)
on Mar 01, 2005 at 10:06 UTC ( #435340=note: print w/ replies, xml ) Need Help??

in reply to Re: the basic datatypes, three
in thread the basic datatypes, three

Can anyone tell me why my order of output is like this ? Unlikely.

For all practical purposes you cannot rely on the hash elements to be stored in any particular order. It depends on how many elements the hash has, on the value of the keys, and in recent Perl versions can be additionally randomized to prevent certain types of attacks.

The order of the elements as returned by the keys, each and values functions is not the order of insertion or follows the alphabet. The order produced by these three functions is however internally consistent (meaning you can iterate over keys and values separately and they will match).

You can sort the keys (for example) alphabetically if you need to do this, but you cannot recover the order of insertion.

This may seem inconvenient, but it is (a fundamental) part of how a hash works. It is not made to retrieve elements in a certain order, but it is very fast at single-element lookups. Testing if an element exists is for example much more efficient in a hash than in an array.

Comment on Re^2: the basic datatypes, three
Select or Download Code

Log In?

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

How do I use this? | Other CB clients
Other Users?
Others meditating upon the Monastery: (8)
As of 2015-11-28 12:26 GMT
Find Nodes?
    Voting Booth?

    What would be the most significant thing to happen if a rope (or wire) tied the Earth and the Moon together?

    Results (741 votes), past polls