in reply to Re: Map with Regex Replace
in thread Map with Regex Replace
providing that the array you are feeding is not read only (i.e. @ARGV works but qw|1.2 3.4 5.6| would require the lexical misdirection) and you don't care if it mutates.map { s!.*/!!; $_ } ...
I think the more natural way of expressing this, since you are really operating on every element, would be to write
The general rule of thumb/best practice-y thing is you should only use maps when you use the return value; and for/foreach when you are operating on each element. The lexical assignment in Corion's solution essentially turns the operation into something mappier.s!.*/!! for @ARGV; print "Lexicons: ", join(", ", @ARGV[FIRST_LEXICON .. $#ARGV]), "\n";
#11929 First ask yourself `How would I do this without a computer?' Then have the computer do it the same way.
|
|---|