微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

G方法的华丽升级

ThinkPHP长期以来需要通过debug_start、debug_end方法甚至Debug类才能完成的功能,3.1版本中被一个简单的G方法取代了,不可不谓是一次华丽升级
G方法的作用包括标记位置和区间统计两个功能,下面来看下具体用法

标记位置

G方法的第一个用法就是标记位置,例如:
G('begin');
表示把当前位置标记为begin标签,并且记录当前位置的执行时间,如果环境支持的话,还能记录内存占用情况。可以在任何位置调用G方法标记

运行时间统计

标记位置后,我们就可以再次调用G方法进行区间统计了,例如:
G('begin');
// ...其他代码
G('end');
// ...也许这里还有其他代码
// 进行统计区间
echo G('begin','end').'s';
G('begin','end') 表示统计begin位置到end位置的执行时间(单位是秒),begin必须是一个已经标记过的位置,如果这个时候end位置还没被标记过,则会自动把当前位置标记为end标签输出的结果类似于:
0.0056s
认的统计精度是小数点后4位,如果觉得这个统计精度不够,还可以设置例如:
G('begin','end',6).'s';
可能的输出会变成:
0.005587s

内存开销统计

如果你的环境支持内存占用统计的话,还可以使用G方法进行区间内存开销统计(单位为kb),例如:
echo G('begin','m').'kb';
第三个参数使用m表示进行内存开销统计输出的结果可能是:
625kb
同样,如果end标签没有被标记的话,会自动把当前位置先标记位end标签
如果环境不支持内存统计,则该参数无效,仍然会进行区间运行时间统计

忘掉debug_start、debug_end吧,大道至简,你懂的~

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐