Click here to get back home

FAQ 3.6 How do I profile my Perl programs?

 HomeNewsGroups | Search | About
 comp.lang.perl.misc    Post an article   get this group's latest topics as an RSS feed add this group's latest topics to your My MSN content add this group's latest topics to your My Yahoo content
Subject Author Date
FAQ 3.6 How do I profile my Perl programs? PerlFAQ Server 04-30-2008
Posted by PerlFAQ Server on April 30, 2008, 9:03 am
Please log in for more thread options
This is an excerpt from the latest version perlfaq3.pod, which
comes with the standard Perl distribution. These postings aim to
reduce the number of repeated questions as well as allow the community
to review and update the answers. The latest version of the complete
perlfaq is at http://faq.perl.org .

--------------------------------------------------------------------

3.6: How do I profile my Perl programs?

You should get the Devel::DProf module from the standard distribution
(or separately on CPAN) and also use Benchmark.pm from the standard
distribution. The Benchmark module lets you time specific portions of
your code, while Devel::DProf gives detailed breakdowns of where your
code spends its time.

Here's a sample use of Benchmark:

use Benchmark;

@junk = `cat /etc/motd`;
$count = 10_000;

timethese($count, {
'map' => sub { my @a = @junk;
map { s/a/b/ } @a;
return @a },
'for' => sub { my @a = @junk;
for (@a) { s/a/b/ };
return @a },
});

This is what it prints (on one machine--your results will be dependent
on your hardware, operating system, and the load on your machine):

Benchmark: timing 10000 iterations of for, map...
for: 4 secs ( 3.97 usr 0.01 sys = 3.98 cpu)
map: 6 secs ( 4.97 usr 0.00 sys = 4.97 cpu)

Be aware that a good benchmark is very hard to write. It only tests the
data you give it and proves little about the differing complexities of
contrasting algorithms.



--------------------------------------------------------------------

The perlfaq-workers, a group of volunteers, maintain the perlfaq. They
are not necessarily experts in every domain where Perl might show up,
so please include as much information as possible and relevant in any
corrections. The perlfaq-workers also don't have access to every
operating system or platform, so please include relevant details for
corrections to examples that do not work on particular platforms.
Working code is greatly appreciated.

If you'd like to help maintain the perlfaq, see the details in
perlfaq.pod.

Similar ThreadsPosted
FAQ 3.6 How do I profile my Perl programs? January 26, 2005, 12:03 pm
FAQ 3.6 How do I profile my Perl programs? April 24, 2005, 11:03 am
FAQ 3.6 How do I profile my Perl programs? July 10, 2005, 4:03 am
FAQ 3.6 How do I profile my Perl programs? August 27, 2005, 4:03 am
FAQ 3.6 How do I profile my Perl programs? January 27, 2006, 6:03 pm
FAQ 3.6 How do I profile my Perl programs? February 10, 2006, 12:03 pm
FAQ 3.6 How do I profile my Perl programs? March 15, 2006, 9:03 am
FAQ 3.6 How do I profile my Perl programs? May 21, 2006, 3:03 pm
FAQ 3.6 How do I profile my Perl programs? July 18, 2006, 3:03 pm
FAQ 3.6 How do I profile my Perl programs? October 16, 2006, 9:03 pm

Our other projects:

Art Dolls, Fairies and Mermaids - Sunnyfaces.net

Roy's Linux, Programming and Search Engines messages

1-Script XML SitemapXML Sitemap