in reply to Performance Question
Also, if you want to talk about performance, the way in which you're looking for variables to change is going to be much more of a problem. Since you're going through each field on each line, this is roughly O(n^2) in complexity. That could get really expensive if you're running those regexes on a large number of fields/lines. Rather than checking for all of the fields on each iteration of the while loop, you might do something like this:
while(<MYTEMPLATE>){ # get the names of the fields on this line my @variables = $_ =~ m/<\?--(\S+?)-->/g; for my $variable ( @variables ){ # replace the tag with the value of the variable # if there is one. s/<\?--$variable-->/$$variable/g if $$variable; } }
That should yield something more like O(n), which should be noticeably faster in most cases (remember that O(n^2) smaller than O(n) for small numbers), less error prone and since it's dynamic, you won't have to update it when there's a new field to check.
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^2: Performance Question
by Rhandom (Curate) on Feb 28, 2007 at 17:46 UTC | |
by agianni (Hermit) on Feb 28, 2007 at 17:56 UTC | |
by blazar (Canon) on Mar 01, 2007 at 10:34 UTC | |
|
Re^2: Performance Question
by blazar (Canon) on Mar 01, 2007 at 10:24 UTC |