ThinkPHP3.1新特性之G方法的使用
2014-06-19 00:00
671 查看
长期以来ThinkPHP都是需要通过debug_start、debug_end方法甚至Debug类才能完成那些调试的功能,而在ThinkPHP3.1版本中,这些复杂的功能被一个简单的G方法取代了,这不可不谓是一次华丽升级。
G方法的作用包括标记位置和区间统计两个功能,下面来看下具体用法:
1.标记位置
G方法的第一个用法就是标记位置,例如:
表示把当前位置标记为begin标签,并且记录当前位置的执行时间,如果环境支持的话,还能记录内存占用情况。可以在任何位置调用G方法标记。
2.运行时间统计
标记位置后,我们就可以再次调用G方法进行区间统计了,例如:
G('begin','end') 表示统计begin位置到end位置的执行时间(单位是秒),begin必须是一个已经标记过的位置,如果这个时候end位置还没被标记过,则会自动把当前位置标记为end标签,输出的结果类似于:
默认的统计精度是小数点后4位,如果觉得这个统计精度不够,还可以设置例如:
可能的输出会变成:
3.内存开销统计
如果你的环境支持内存占用统计的话,还可以使用G方法进行区间内存开销统计(单位为kb),例如:
第三个参数使用m表示进行内存开销统计,输出的结果可能是:
同样,如果end标签没有被标记的话,会自动把当前位置先标记为end标签。
如果环境不支持内存统计,则该参数无效,仍然会进行区间运行时间统计。
忘掉debug_start、debug_end吧,大道至简,你懂的~
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吧,大道至简,你懂的~
相关文章推荐
- ThinkPHP3.1新特性之G方法的使用
- ThinkPHP3.1新特性之命名范围的使用
- thinkphp3.1和3.2引入phpexcel第三方类库方法及使用详解
- ThinkPHP3.1新特性之命名范围的使用
- C#嵌套类的使用方法及特性
- 国内开源项目“C语言正则表达式”——特性、使用方法、正则模式等介绍。
- C# 3.0新特性初步研究 Part2:使用扩展方法_C#教程
- C# 3.0新特性初步研究 Part2:使用扩展方法_C#教程
- Data Access Application Block(Enterprise Library 3.1)的下载以及使用方法介绍
- jquery之操作元素属性和特性(获取特性值,attr(name)方法的使用)
- 基于Visual Studio2010讲解C#4.0语法(3)--C#4.0中特性(Attributes)的使用方法
- C# 3.0新特性初步研究 Part2:使用扩展方法_C#教程
- jquery之操作元素属性和特性(删除特性,removeAttr()方法的使用)
- 默认参数是C++的特性,C中不支持 —— 在C中通过默认参数列表使用默认参数的方法
- CUDA 4.0中P2P与UVA的性特性使用方法
- C#嵌套类的使用方法及特性
- C#嵌套类的使用方法及特性
- C# 3.0新特性初步研究 Part2:使用扩展方法
- 第一课 掌握java annotation特性与使用方法
- thinkphp的静态缓存使用方法