全局记录程序片段的运行时间 正确找到程序逻辑耗时多的断点
2011-01-06 00:00
447 查看
// 定义全局变量 记录时间 $_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
相关文章推荐
- 全局记录程序片段的运行时间 正确找到程序逻辑耗时多的断点
- C++中两种常用的记录程序运行时间的方法的总结
- C++记录程序运行时间
- C++记录程序运行时间
- c++记录程序运行时间
- 记录程序运行时间
- 题目:C++中两种常用的记录程序运行时间的方法的总结
- WN7 上IIS7运行asp+access网站出现错误: ADODB.Connection 错误 '800a0e7a'未找到提供程序。该程序可能未正确安装
- python记录程序运行时间
- python记录程序运行时间的三种方法
- c++记录程序运行时间
- 最简单的记录程序运行时间的方法:[记录PHP程序运行消耗时间]
- R记录程序运行时间
- R语言记录程序运行的时间
- 用c++实现记录程序运行时间的类
- Shell 下记录程序运行时间
- c++中记录程序运行时间的函数
- matlab中记录程序运行时间
- C#记录程序运行时间记录显示
- 记录程序运行时间的程序实例