in reply to hash property
The standard hash does not maintain any order, if you want some order being stored, for example the order pairs being added, then you have to do this your self (or use some other modules).
If you prefer existing modules, check out Tie::IxHash.
If you want to do it yourself, here is some OO solution I had, which I called it OrderedHash. The code given below is strictly for the purpose to explain the structure more clearly, not any kind of actual implementation.
This OrderedHash structure contains two parts:package OrderedHash; use strict; sub new { my $self = {}; $self->{INDEX} = {}; $self->{PAIRS} = []; bless $self; return $self; } sub set { my ($self, $key, $value) = @_; push @{$self->{PAIRS}}, $key; $self->{INDEX}->{$key} = $#{$self->{PAIRS}}; push @{$self->{PAIRS}}, $value; } sub get { my ($self, $key) = @_; return $self->{PAIRS}->[$self->{INDEX}->{$key} + 1]; } sub list_in_order { my $self = shift; my $is_key = 1; foreach (@{$self->{PAIRS}}) { if (!$is_key) { print "$_\n"; } else { print "[$_] = "; } $is_key = !$is_key; } } 1; use OrderedHash; use Data::Dumper; use strict; my $oh = new OrderedHash; $oh->set("a", 1); $oh->set("b", 2); $oh->set("c", 3); print Dumper($oh); $oh->list_in_order;
|
|---|