I'm researching some performance problems with one of our Web sites and stumbled across some legacy code that's getting pulled into our system. This code uses $` and $' variables with regular expression matches. From the perlre docs (emphasis mine):
WARNING: Once Perl sees that you need one of "$&", "$`", or "$'" anywhere in the program, it has to provide them for every pattern match. This may substantially slow your program.
In fact, in tests that I've run, it appears that the mere existence of these variables will trigger this behavior, regardless of whether or not the code that accesses them will be executed. Removing these variables seems to consistently get me a ten percent bump in regex performance.
Since mod_perl is a persistent Perl interpreter embedded in the Web server, it seems to me that any reference to these variables will impact all regex matches in a mod_perl environment, regardless of whether or not my code actually uses those variables. Is this the case? I don't know enough about benchmarking snippets in a mod_perl environment to easily verify this.
Are you posting in the right place? Check out Where do I post X? to know for sure.
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
Want more info? How to link or
or How to display code and escape characters
are good places to start.