Posted in PHP onJanuary 06, 2011
// 定义全局变量 记录时间 $_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
全局记录程序片段的运行时间 正确找到程序逻辑耗时多的断点
声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@