新手瞎写的,欢迎扩展或批评指导。
目前仅记录耗时与内存占用,还有其他需要记录的属性吗?
有些注释部分标记了疑问,欢迎高人解答。
耗时内存记录类
<?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房产程序|BBWPS]功能介绍 1、5种信息类别发布:出租、求租、出售、求购、楼盘信息,支持会员发布信息审核; 2、灵活的信息参数设置; 3、充足的信息字段; 4、简单易用的发布/编辑功能,支持配图上传; 5、灵活的信息管理功能; 6、信息输出伪静态,方便搜索引擎抓取数据; 7、支持RSS输出; 8、内置数据高速缓冲技术,可灵活设置缓冲功能是否启动及过期时间; 9、支持 Google 地图
0
<?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速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号