<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed'); /** * CodeIgniter * * An open source application development framework for PHP 5.1.6 or newer * * @package CodeIgniter * @author ExpressionEngine Dev Team * @copyright Copyright (c) 2008 - 2011, EllisLab, Inc. * @license http://codeigniter.com/user_guide/license.html * @link http://codeigniter.com * @since Version 1.0 * @filesource */ // ------------------------------------ /** * CodeIgniter Benchmark Class * * This class enables 能够 you to mark points and calculate 计算 the time difference 差异 * between them. Memory consumption can also be displayed. * * @package CodeIgniter * @subpackage Libraries * @category Libraries * @author ExpressionEngine Dev Team * @link http://codeigniter.com/user_guide/libraries/benchmark.html */ class CI_Benchmark { /** * List of all benchmark markers and when they were added * 用来存储基准测试类标记的数组 * @var array */ var $marker = array(); // -------------------------------- /** * Set a benchmark marker * 设置一个标记点 * Multiple calls to this function can be made so that several * execution points can be timed * * @access public * @param string $name name of the marker * @return void */ function mark($name) { // 在程序的任意地方调用方法时,会记录当前的时间点。 $this->marker[$name] = microtime(); } // -------------------------------- /** * Calculates the time difference between two marked points. * 计算出两个时间点之间的时间。 * If the first parameter is empty this function instead returns the * {elapsed_time} pseudo-variable 虚假变量. This permits 许可 the full system * execution time to be shown in a template. The output class will * swap the real value for this variable. * * @access public * @param string a particular marked point * @param string a particular marked point * @param integer the number of decimal places * @return mixed */ function elapsed_time($point1 = '', $point2 = '', $decimals = 4) { /* * 如果没有给出明确的时间点,那么会计算出整个程序运行的时间。 * 怎么可以做到计算出整个程序的运行时间的呢?其实执行此计算的是Output组件。 * 而调用Benchmark::elapsed_time();(无参数)的时候,实质上先返回的并不是 * 整个程序运行的时间,也不可能做到,实质返回的是一个{elapsed_time}标签,然后 * Output在处理输出的时候,再计算出整个程序运行时间,因为处理输出阶段程序可以视 * 为处于最后阶段,于是可以近似计算出总时间,然后把输出中的{elapsed_time}替换掉。 * 下面的memory_usage()原理相同。 */ 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 * * This function returns the {memory_usage} pseudo-variable. * This permits it to be put it anywhere in a template * without the memory being calculated until the end. * The output class will swap the real value for this variable. * * @access public * @return string */ function memory_usage() { return '{memory_usage}'; } } // END CI_Benchmark class /* End of file Benchmark.php */ /* Location: ./system/core/Benchmark.php */
详细解决方案
CI框架源码翻阅-基准测试类Benchmark.php
热度:184 发布时间:2013-03-04 17:22:12.0
相关解决方案
- 手机 J2ME MIDP 性能测试用具(MIDP BenchMark)
- redis 执行性能检测指令报错:-bash: redis-benchmark: command not found
- KAIST : Multispectral Pedestrian Detection: Benchmark Dataset and Baseline
- 【TVM学习七】Reproduce Benchmark
- 什么情况下应该设置 cudnn.benchmark = True?
- 【立体匹配和深度估计】The KITTI Vision Benchmark Suite
- flash benchmark test
- APACHE自带的并发测试工具--Apache Benchmark
- OTB Tracker Benchmark v1.0源码使用
- Structural analysis of fault isolability in the DAMADICS benchmark
- Java Grande benchmark suite总结
- 一行代码提升卷积神经网络的计算效率,加速神器torch.backends.cudnn.benchmark
- Benchmark Analysis of Representative Deep Neural Network Architecture论文笔记
- 车间调度测试集(经典算例、benchmark set)
- uva-10916 - Factstone Benchmark
- benchmark pm2的cluster模式发布web app的性能与相关问题解决方法
- 教程直播第6期 | OceanBase 如何进行 Benchmark 测试及调优
- grpc benchmark
- OTB测试之Visual Tracker Benchmark v1.0全过程配置流程
- RPC Benchmark 测试: 将开源RPC框架聚在一起是一种怎样的体验?
- Ruby Benchmark 模块提供了测量和报告Ruby代码运行使用时间的方法。
- MMDetection: Open MMLab Detection Toolbox and Benchmark
- Redis-性能测试(redis-benchmark)
- 数据集2020(一)GraspNet-1Billion: A Large-Scale Benchmark for General Object Grasping
- R4C: A Benchmark for Evaluating RC Systems to Get the Right Answer for the Right Reason
- AI Benchmark v4测试项更新以及榜单数据解读
- Semantic3D:A New Large-Scale Point Cloud Classification Benchmark