欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

全局记录程序片段的运行时间 正确找到程序逻辑耗时多的断点

程序员文章站 2022-05-14 12:25:04
复制代码 代码如下: // 定义全局变量 记录时间 $_timer_id = 0; // 函数设置全局变量 记录各个断点的运行所需时间 function maketimer...
复制代码 代码如下:

// 定义全局变量 记录时间
$_timer_id = 0;
// 函数设置全局变量 记录各个断点的运行所需时间
function maketimer( $notes, $onoff=false )
{
if( $onoff )
{
global $_timer_id;
$globals['timer'][$_timer_id][0] = microtime(true);
$globals['timer'][$_timer_id][1] = $notes;
$_timer_id++;
}
}
// 把全局运行时间情况输出
function tracetimer()
{
$timer_str = '';
$g_timer = count($globals['timer'])-1;
if( $g_timer>0 )
{
for( $i=0;$i<$g_timer;$i++ )
{
$dif_time = number_format( ($globals['timer'][$i+1][0] - $globals['timer'][$i][0]), 3 );
$timer_str .= 'dif: '.$dif_time.' '.$globals['timer'][$i][1]."\n";
}
$dif_time = number_format( (microtime(true) - $globals['timer'][$g_timer][0]), 3 );
$timer_str .= 'dif: '.$dif_time.' '.$globals['timer'][$g_timer][1]."\n";
}
return $timer_str;
}
使用方法:
// 开始时间
maketimer( ' line:'.__line__ );
$imgstrpos = strpos($str, '<img'.$imgstr);
maketimer( ' line:'.__line__ );
$str_p = substr($str_noimg, 0, $imgstrpos);
maketimer( ' line:'.__line__ );
$str_n = substr($str_noimg, $imgstrpos, strlen($str_noimg));
maketimer( ' line:'.__line__ );
$pst_exc_imgs = $str_p.'<img '.$imgstr.'>'.$str_n." ";
maketimer( ' line:'.__line__ );
// 记录到日志中
error_log( tracetimer(), 3, '/tmp/'.basename(__file__).'.log' );
// 或者直接输出
echo tracetimer();

at 2010-05-14 09:20