Beefy Boxes and Bandwidth Generously Provided by pair Networks
Syntactic Confectionery Delight
 
PerlMonks  

Re: Re: Re: Re: Hash references and illegal octal digits

by MarkM (Curate)
on Dec 24, 2002 at 20:15 UTC ( [id://222133]=note: print w/replies, xml ) Need Help??


in reply to Re: Re: Re: Hash references and illegal octal digits
in thread Hash references and illegal octal digits

It is usually considered bad form to modify $_ during a map{} operation. People expect map{} to create a new list from an existing list, without modifying the existing list.

The expression can be written out clearer, more accurately, and using less intermediate memory by using the following code instead:

my %hash; for (@array) { if (/^([^,]+)(?:,(.*))?$/) { $hash{$1} = $2; } }

This also has the side effect of handling the case where the input takes the form "1009," or "1009". For "1009," the key will map to an empty string. For "1009" the key will map to the undefined value.

The regular expression removes the need for chomp() as the $ at the end of the regular expression will not swallow the "\n".

If efficiency is the true goal, the following code has the exact same effect:

my %hash; /^([^,]+)(?:,(.*))?$/s && ($hash{$1} = $2) for @array;

If a few CPU ticks can be spared, the former is far more preferable to the latter.

Log In?
Username:
Password:

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

How do I use this?Last hourOther CB clients
Other Users?
Others examining the Monastery: (3)
As of 2024-04-24 18:09 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found