* lib/profiler.rb: Add Profiler documentation by Gonzalo Rodriguez.
[Bug #5816] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@34773 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
774cf315e8
commit
480ea9ffae
@ -1,3 +1,8 @@
|
|||||||
|
Fri Feb 24 07:13:20 2012 Eric Hodel <drbrain@segment7.net>
|
||||||
|
|
||||||
|
* lib/profiler.rb: Add Profiler documentation by Gonzalo Rodriguez.
|
||||||
|
[Bug #5816]
|
||||||
|
|
||||||
Fri Feb 24 08:08:38 2012 Aaron Patterson <aaron@tenderlovemaking.com>
|
Fri Feb 24 08:08:38 2012 Aaron Patterson <aaron@tenderlovemaking.com>
|
||||||
|
|
||||||
* ext/psych/parser.c: set parser encoding based on the YAML input
|
* ext/psych/parser.c: set parser encoding based on the YAML input
|
||||||
|
@ -1,3 +1,62 @@
|
|||||||
|
# Profile provides a way to Profile your Ruby application.
|
||||||
|
#
|
||||||
|
# Profiling your program is a way of determining which methods are called and
|
||||||
|
# how long each method takes to complete. This way you can detect which
|
||||||
|
# methods are possible bottlenecks.
|
||||||
|
#
|
||||||
|
# Profiling your program will slow down your execution time considerably,
|
||||||
|
# so activate it only when you need it. Don't confuse benchmarking with
|
||||||
|
# profiling.
|
||||||
|
#
|
||||||
|
# There are two ways to activate Profiling:
|
||||||
|
#
|
||||||
|
# == Command line
|
||||||
|
#
|
||||||
|
# Run your Ruby script with <code>-rprofile</code>:
|
||||||
|
#
|
||||||
|
# ruby -rprofile example.rb
|
||||||
|
#
|
||||||
|
# If you're profiling an executable in your <code>$PATH</code> you can use
|
||||||
|
# <code>ruby -S</code>:
|
||||||
|
#
|
||||||
|
# ruby -rprofile -S some_executable
|
||||||
|
#
|
||||||
|
# == From code
|
||||||
|
#
|
||||||
|
# Just require 'profile':
|
||||||
|
#
|
||||||
|
# require 'profile'
|
||||||
|
#
|
||||||
|
# def slow_method
|
||||||
|
# 5000.times do
|
||||||
|
# 9999999999999999*999999999
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# def fast_method
|
||||||
|
# 5000.times do
|
||||||
|
# 9999999999999999+999999999
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# slow_method
|
||||||
|
# fast_method
|
||||||
|
#
|
||||||
|
# The output in both cases is a report when the execution is over:
|
||||||
|
#
|
||||||
|
# ruby -rprofile example.rb
|
||||||
|
#
|
||||||
|
# % cumulative self self total
|
||||||
|
# time seconds seconds calls ms/call ms/call name
|
||||||
|
# 68.42 0.13 0.13 2 65.00 95.00 Integer#times
|
||||||
|
# 15.79 0.16 0.03 5000 0.01 0.01 Fixnum#*
|
||||||
|
# 15.79 0.19 0.03 5000 0.01 0.01 Fixnum#+
|
||||||
|
# 0.00 0.19 0.00 2 0.00 0.00 IO#set_encoding
|
||||||
|
# 0.00 0.19 0.00 1 0.00 100.00 Object#slow_method
|
||||||
|
# 0.00 0.19 0.00 2 0.00 0.00 Module#method_added
|
||||||
|
# 0.00 0.19 0.00 1 0.00 90.00 Object#fast_method
|
||||||
|
# 0.00 0.19 0.00 1 0.00 190.00 #toplevel
|
||||||
|
|
||||||
module Profiler__
|
module Profiler__
|
||||||
# internal values
|
# internal values
|
||||||
@@start = @@stack = @@map = nil
|
@@start = @@stack = @@map = nil
|
||||||
|
Loading…
x
Reference in New Issue
Block a user