欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ThinkPHP3.1新特性之G方法的使用

程序员文章站 2022-07-20 23:17:46
长期以来thinkphp都是需要通过debug_start、debug_end方法甚至debug类才能完成那些调试的功能,而在thinkphp3.1版本中,这些复杂的功能被...

长期以来thinkphp都是需要通过debug_start、debug_end方法甚至debug类才能完成那些调试的功能,而在thinkphp3.1版本中,这些复杂的功能被一个简单的g方法取代了,这不可不谓是一次华丽升级。

g方法的作用包括标记位置和区间统计两个功能,下面来看下具体用法:

1.标记位置

g方法的第一个用法就是标记位置,例如:

g('begin');

表示把当前位置标记为begin标签,并且记录当前位置的执行时间,如果环境支持的话,还能记录内存占用情况。可以在任何位置调用g方法标记。

2.运行时间统计

标记位置后,我们就可以再次调用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

3.内存开销统计

如果你的环境支持内存占用统计的话,还可以使用g方法进行区间内存开销统计(单位为kb),例如:

echo g('begin','end','m').'kb';

第三个参数使用m表示进行内存开销统计,输出的结果可能是:

625kb

同样,如果end标签没有被标记的话,会自动把当前位置先标记为end标签
如果环境不支持内存统计,则该参数无效,仍然会进行区间运行时间统计。

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