首页 > php教程 > PHP源码 > 正文

[PHP]简单的耗时内存记录类

PHP中文网
发布: 2016-05-25 16:59:04
原创
1488人浏览过

新手瞎写的,欢迎扩展或批评指导。
目前仅记录耗时与内存占用,还有其他需要记录的属性吗?
有些注释部分标记了疑问,欢迎高人解答。

  1. 耗时内存记录类

<?php
 /**
 * 耗时内存记录类,记录代码消耗
 */
class Test
{
    private static $d = array();//用于存储记录
 
    public static function m($str=""){//记录时间与内存,m表示mark
        $o=array();
        if($str)
            $o['title']= $str;
        else{
            $o['title']='第'.(count(self::$d)+1).'部分';
        }
        list($usec,$sec)=explode(" ",microtime());
        $o['time']=(float)$usec+(float)$sec;//这行是copy来的,不加(float)会怎么样?
        $o['memory']= memory_get_usage();
        self::$d[]=$o;
    }
 
    public static function show(){//输出
        self::m();
        $arr =& self::$d;
        $r=null;    
        $n=count($arr)-1;
        for($i=0; $i<$n; $i++){
            $r.=$arr[$i]['title'].'<br />
耗时增加:'. number_format(($arr[$i+1]['time'] - $arr[$i]['time']),6) .'<br />
内存增加:'.( $arr[$i+1]['memory'] - $arr[$i]['memory'] ).'<br /><br />';
        }
        $r.='汇总<br />
总耗时:'. number_format(($arr[$n]['time'] - $arr[0]['time']),6) .'<br />
总内存:'.( $arr[$n]['memory'] - $arr[0]['memory'] ).'<br /><br />';
        echo $r;
    }
}
登录后复制

2.使用方法

<?php
$arr1=$arr2=$arr3=array();
$i=$j=$n=9999;
 
Test::m('测试 $arr1[]=$i');
while($i--)
    $arr1[]=$i;
 
Test::m('测试 array_push($arr2,$j)');
while($j--)
    array_push($arr2,$j);
 
Test::m('测试 $arr3[$n]=$n ');
while($n--)
    $arr3[$n]=$n;
 
 
Test::show();//求教,有没有简单办法节省这行代码,静态类可以用析构函数自动调用吗?
 
 
 
/*
输出
 
测试 $arr1[]=$i
耗时增加:0.002209
内存增加:1412040
 
测试 array_push($arr2,$j)
耗时增加:0.004101
内存增加:1411968
 
测试 $arr3[$n]=$n 
耗时增加:0.002527
内存增加:1411984
 
汇总
总耗时:0.008837
总内存:4235992
 
*/
登录后复制
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号