Profiling is an indispensable measure for analyzing and optimizing the performance of your program. A typical profiler like GNU gprof
will complete this task by running your program after a special compilation.
There are 3 forms of the profiling analysis:
-
flat profile: how much time the program spent in each function and how many times the function was called.
-
call graph: for each function, which function called it and which other functions it called, and how many times.
-
annotated source: a listing of the program source code, which is labeled with the number of times each line of the program was executed.
Compiler options for generating the code which can be profiled by gprof
:
-
-pg
: enable profiling bygprof
, which is always mandatory. -
-g
: enable annotated source profiling. -
-a
: enable basic-block counting, which is required by the annotated source profiling. However, this option does not appear ingcc
org++
.
Options for gprof
command
-
-p
: generate flat profile. -
-q
: generate call graph. -
-l
: enable line-by-line profiling. -
-s
: summarize profile data from different files intogmon.sum
.
Steps for using gprof
:
-
Compile the program for
gprof
:g++ -std=gnu++11 -g -O2 -o output input.cpp -gp
-
Run the program:
./output1
. After execution, the profiling data will be stored in the filegmon.out
. -
Call
gprof
command with the generatedgmon
file as argument to generate profiling reports.