發(fā)表日期:2018-12 文章編輯:小燈 瀏覽次數(shù):3223
開發(fā)過程中,有些時候為了測試性能,經(jīng)常需要調(diào)試某段代碼的運行時間或者內(nèi)存占用開銷,系統(tǒng)提供了think\Debug
類可以很方便的獲取某個區(qū)間的運行時間和內(nèi)存占用情況。 例如:
Debug::remark('begin');// ...其他代碼段Debug::remark('end');// ...也許這里還有其他代碼// 進行統(tǒng)計區(qū)間echo Debug::getRangeTime('begin','end').'s';
表示統(tǒng)計begin位置到end位置的執(zhí)行時間(單位是秒),begin必須是一個已經(jīng)標記過的位置,如果這個時候end位置還沒被標記過,則會自動把當前位置標記為end標簽,輸出的結(jié)果類似于:0.0056s
默認的統(tǒng)計精度是小數(shù)點后4位,如果覺得這個統(tǒng)計精度不夠,還可以設置例如:
echo Debug::getRangeTime('begin','end',6).'s';
可能的輸出會變成:0.005587s
如果你的環(huán)境支持內(nèi)存占用統(tǒng)計的話,還可以使用getRangeMem
方法進行區(qū)間內(nèi)存開銷統(tǒng)計(單位為kb),例如:
echo Debug::getRangeMem('begin','end').'kb';
第三個參數(shù)使用m表示進行內(nèi)存開銷統(tǒng)計,輸出的結(jié)果可能是:625kb
同樣,如果end標簽沒有被標記的話,會自動把當前位置先標記位end標簽。
系統(tǒng)還提供了助手函數(shù)debug
用于完成相同的作用,上面的代碼可以改成:
debug('begin');// ...其他代碼段debug('end');// ...也許這里還有其他代碼// 進行統(tǒng)計區(qū)間echo debug('begin','end').'s';echo debug('begin','end',6).'s';echo debug('begin','end','m').'kb';
日期:2018-12 瀏覽次數(shù):4987
日期:2018-12 瀏覽次數(shù):5274
日期:2018-12 瀏覽次數(shù):4349
日期:2018-12 瀏覽次數(shù):3704
日期:2018-12 瀏覽次數(shù):4116
日期:2018-12 瀏覽次數(shù):3668
日期:2018-12 瀏覽次數(shù):3712
日期:2018-12 瀏覽次數(shù):6527
日期:2018-12 瀏覽次數(shù):3481
日期:2018-12 瀏覽次數(shù):3584
日期:2018-12 瀏覽次數(shù):3714
日期:2018-12 瀏覽次數(shù):4839
日期:2018-12 瀏覽次數(shù):3221
日期:2018-12 瀏覽次數(shù):3536
日期:2018-12 瀏覽次數(shù):3338
日期:2018-12 瀏覽次數(shù):3222
日期:2018-12 瀏覽次數(shù):3592
日期:2018-12 瀏覽次數(shù):3461
日期:2018-12 瀏覽次數(shù):4563
日期:2018-12 瀏覽次數(shù):4009
日期:2018-12 瀏覽次數(shù):3521
日期:2018-12 瀏覽次數(shù):4330
日期:2018-12 瀏覽次數(shù):3307
日期:2018-12 瀏覽次數(shù):3297
日期:2018-12 瀏覽次數(shù):3254
日期:2018-12 瀏覽次數(shù):3413
日期:2018-12 瀏覽次數(shù):3697
日期:2018-12 瀏覽次數(shù):3488
日期:2018-12 瀏覽次數(shù):3418
日期:2018-12 瀏覽次數(shù):3473
Copyright ? 2013-2018 Tadeng NetWork Technology Co., LTD. All Rights Reserved.