php实现的Timer页面运行时间监测类


Posted in PHP onSeptember 24, 2014

本文实例讲述了php实现的Timer页面运行时间监测类及其用法,是一款非常实用的PHP类文件。分享给大家供大家参考。具体分析如下:

该php Timer页面运行时间监测类,可按不同key监测不同的运行时间。

Timer.class.php类文件如下:

<?php 
/** Timer class, 计算页面运行时间,可按不同key计算不同的运行时间 
*  Date:  2014-02-28 
*  Author: fdipzone 
*  Ver:  1.0 
* 
*  Func: 
*  public start    记录开始时间 
*  public end     记录结束时间 
*  public getTime   计算运行时间 
*  pulbic printTime  输出运行时间 
*  private getKey    获取key 
*  private getMicrotime 获取microtime 
*/ 
 
class Timer{ // class start 
 
  private $_start = array(); 
  private $_end = array(); 
  private $_default_key = 'Timer'; 
  private $_prefix = 'Timer_'; 
 
  /** 记录开始时间 
  * @param String $key 标记 
  */ 
  public function start($key=''){ 
    $flag = $this->getKey($key); 
    $this->_start[$flag] = $this->getMicrotime(); 
  } 
 
  /** 记录结束时间 
  * @param String $key 标记 
  */ 
  public function end($key=''){ 
    $flag = $this->getKey($key); 
    $this->_end[$flag] = $this->getMicrotime(); 
  } 
 
  /** 计算运行时间 
  * @param String $key 标记 
  * @return float 
  */ 
  public function getTime($key=''){ 
    $flag = $this->getKey($key); 
    if(isset($this->_end[$flag]) && isset($this->_start[$flag])){ 
      return (float)($this->_end[$flag] - $this->_start[$flag]); 
    }else{ 
      return 0; 
    } 
  } 
 
  /** 输出页面运行时间 
  * @param String $key 标记 
  * @return String 
  */ 
  public function printTime($key=''){ 
    printf("%srun time %f ms\r\n", $key==''? $key : $key.' ', $this->getTime($key)*1000); 
  } 
 
  /** 获取key 
  * @param String $key 标记 
  * @return String 
  */ 
  private function getKey($key=''){ 
    if($key==''){ 
      return $this->_default_key; 
    }else{ 
      return $this->_prefix.$key; 
    } 
  } 
 
  /** 获取microtime 
  */ 
  private function getMicrotime(){ 
    list($usec, $sec) = explode(' ', microtime()); 
    return (float)$usec + (float)$sec; 
  } 
} // class end 
?>

demo示例代码如下:

<?php 
 
require 'Timer.class.php'; 
 
$timer = new Timer(); 
$timer->start(); 
 
$timer->start('program1'); 
usleep(mt_rand(100000,500000)); 
$timer->end('program1'); 
$timer->printTime('program1'); 
 
$timer->start('program2'); 
usleep(mt_rand(100000,500000)); 
$timer->end('program2'); 
$timer->printTime('program2'); 
 
$timer->end(); 
$timer->printTime(); 
 
?>

demo运行输出:

program1 run time 163.285971 ms 
program2 run time 100.347042 ms 
run time 264.035940 ms

完整实例源码点击此处本站下载。

希望本文所述对大家的PHP程序设计有所帮助。

PHP 相关文章推荐
php中用加号与用array_merge合并数组的区别深入分析
Jun 03 PHP
php中3种方法删除字符串中间的空格
Mar 10 PHP
PHP正则提取不包含指定网址的图片地址的例子
Apr 21 PHP
Yii不依赖Model的表单生成器用法实例
Dec 04 PHP
Opcache导致php-fpm崩溃nginx返回502
Mar 02 PHP
php实现简单的语法高亮函数实例分析
Apr 27 PHP
php根据一个给定范围和步进生成数组的方法
Jun 19 PHP
php+ajax实现无刷新的新闻留言系统
Dec 21 PHP
PHP 获取指定地区的天气实例代码
Feb 08 PHP
ThinkPHP 3.2.2实现事务操作的方法
May 05 PHP
详解如何在云服务器上部署Laravel
Jun 30 PHP
Ubuntu 16.04中Laravel5.4升级到5.6的步骤
Dec 07 PHP
php密码生成类实例
Sep 24 #PHP
PHP中file_get_contents高?用法实例
Sep 24 #PHP
php实现的Cookies操作类实例
Sep 24 #PHP
PHP实现支持GET,POST,Multipart/form-data的HTTP请求类
Sep 24 #PHP
php过滤html标记属性类用法实例
Sep 23 #PHP
php广告加载类用法实例
Sep 23 #PHP
php实现根据url自动生成缩略图的方法
Sep 23 #PHP
You might like
php单件模式结合命令链模式使用说明
2008/09/07 PHP
浏览器关闭后,能继续执行的php函数(ignore_user_abort)
2012/08/01 PHP
PHP输出缓存ob系列函数详解
2014/03/11 PHP
Yii框架form表单用法实例
2014/12/04 PHP
PHP+mysql防止SQL注入的方法小结
2019/04/27 PHP
js 图片等比例缩放代码
2010/05/13 Javascript
基于jquery的多彩百分比 动态进度条 投票效果显示效果实现代码
2011/08/28 Javascript
JS防止用户多次提交的简单代码
2013/08/01 Javascript
jQuery获取上传文件的名称的正则表达式
2015/05/21 Javascript
jQuery的Scrollify插件实现滑动到页面下一节点
2015/07/05 Javascript
javascript省市级联功能实现方法实例详解
2015/10/20 Javascript
jQuery实现鼠标选中文字后弹出提示窗口效果【附demo源码】
2016/09/05 Javascript
Bootstrap 填充Json数据的实例代码
2017/01/11 Javascript
JavaScript表单验证的两种实现方法
2017/02/11 Javascript
BootStrap 动态表单效果
2017/06/02 Javascript
nodejs基础之多进程实例详解
2018/12/27 NodeJs
layui switch 开关监听 弹出确定状态转换的例子
2019/09/21 Javascript
node后端服务保活的实现
2019/11/10 Javascript
Python Web框架Pylons中使用MongoDB的例子
2013/12/03 Python
跟老齐学Python之dict()的操作方法
2014/09/24 Python
用Pygal绘制直方图代码示例
2017/12/07 Python
python装饰器简介---这一篇也许就够了(推荐)
2019/04/01 Python
Python:合并两个numpy矩阵的实现
2019/12/02 Python
Python JSON编解码方式原理详解
2020/01/20 Python
完美解决pycharm导入自己写的py文件爆红问题
2020/02/12 Python
python实现飞船大战
2020/04/24 Python
python语言是免费还是收费的?
2020/06/15 Python
美国棒球装备和用品商店:Baseball Savings
2018/06/09 全球购物
元旦晚会上单位领导演讲稿
2014/01/05 职场文书
家长对小学生的评语
2014/01/28 职场文书
个人担保书范文
2014/05/20 职场文书
扶贫办主任查摆“四风”问题个人对照检查材料思想汇报
2014/10/02 职场文书
门球健将观后感
2015/06/16 职场文书
选择比努力更重要?这是长期以来对“努力”的最大误解
2019/07/12 职场文书
奖学金申请书(范文)
2019/08/14 职场文书
python 如何获取页面所有a标签下href的值
2021/05/06 Python