CodeIgniter源码分析之Benchmark.php

10 篇文章 0 订阅
<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');
// ------------------------------------------------------------------------

/**
 * CodeIgniter Benchmark Class
 */
class CI_Benchmark {

 /**
  * List of all benchmark markers and when they were added
  */
 var $marker = array();

 // --------------------------------------------------------------------

 /**
  * Set a benchmark marker
  */
 function mark($name)
 {
  //这个方法其实很简单,就是在程序的任意地方调用地方法时,会记录当前的时间点。
  $this->marker[$name] = microtime();
 }

 // --------------------------------------------------------------------

 /**
  * Calculates the time difference between two marked points.
  * 计算出两个时间点之间的时间。
  */
 function elapsed_time($point1 = '', $point2 = '', $decimals = 4)
 {
  /*
   * 如果没有给出明确的时间点,那么会计算出整个程序运行的时间。
   * 怎么可以做到计算出整个程序的运行时间的呢?其实执行此计算的是Output组件。
   * 而调用Benchmark::elapsed_time();(无参数)的时候,实质上先返回的并不是
   * 整个程序运行的时间,也不可能做到,实质返回的是一个{elapsed_time}标签,然后
   * Output在处理输出的时候,再计算出整个程序运行时间,因为处理输出阶段程序可以视
   * 为处于最后阶段,于是可以近似计算出总时间,然后把输出中的{elapsed_time}替换掉。
   * 下面的memory_usage()原理相同。
   * 详见:core/Output.php 中的_display()方法。
   */
  if ($point1 == '')
  {
   return '{elapsed_time}';
  }

  if ( ! isset($this->marker[$point1]))
  {
   return '';
  }

  if ( ! isset($this->marker[$point2]))
  {
   $this->marker[$point2] = microtime();
  }

  //这里为什么要用到list,是因为microtime();返回值是“msec sec”的格式。
  list($sm, $ss) = explode(' ', $this->marker[$point1]);
  list($em, $es) = explode(' ', $this->marker[$point2]);

  return number_format(($em + $es) - ($sm + $ss), $decimals);
 }

 // --------------------------------------------------------------------

 /**
  * Memory Usage
  */
 function memory_usage()
 {
  //Output::_display();
  return '{memory_usage}';
 }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值