zoukankan      html  css  js  c++  java
  • G方法的华丽升级

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

    标记位置
    G方法的第一个用法就是标记位置,例如:
    1. G('begin');

    复制代码

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

    运行时间统计
    标记位置后,我们就可以再次调用G方法进行区间统计了,例如:
    1. G('begin');
    2. // ...其他代码段
    3. G('end');
    4. // ...也许这里还有其他代码
    5. // 进行统计区间
    6. echo G('begin','end').'s';

    复制代码

    G('begin','end') 表示统计begin位置到end位置的执行时间(单位是秒),begin必须是一个已经标记过的位置,如果这个时候end位置还没被标记过,则会自动把当前位置标记为end标签,输出的结果类似于:

    1. 0.0056s

    复制代码

    默认的统计精度是小数点后4位,如果觉得这个统计精度不够,还可以设置例如:

    1. G('begin','end',6).'s';

    复制代码

    可能的输出会变成:

    1. 0.005587s

    复制代码

    内存开销统计
    如果你的环境支持内存占用统计的话,还可以使用G方法进行区间内存开销统计(单位为kb),例如:
    1. echo G('begin','end','m').'kb';

    复制代码

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

    1. 625kb

    复制代码

    同样,如果end标签没有被标记的话,会自动把当前位置先标记位end标签。
    如果环境不支持内存统计,则该参数无效,仍然会进行区间运行时间统计。
    忘掉debug_start、debug_end吧,大道至简,你懂的~

  • 相关阅读:
    poj 3040 Allowance
    poj 2393 Yogurt factory
    【BZOJ1833】数字计数(ZJOI2010)-数位DP
    【BZOJ4820】硬币游戏(SDOI2017)-概率+高斯消元+KMP
    【BZOJ3626】LCA(LNOI2014)-树链剖分+离线处理
    【BZOJ4817】树点涂色(SDOI2017)-LCT+LCA+线段树
    【BZOJ1135】LYZ(POI2009)-线段树+Hall定理
    【CF392D】Three Arrays-set+multiset
    【51Nod1688】LYKMUL-线段树+乘法原理
    【BZOJ2956】模积和-数论分块
  • 原文地址:https://www.cnblogs.com/zhengyanbin2016/p/5427371.html
Copyright © 2011-2022 走看看