Process:0.2463s (Load:0.0003s Init:0.0010s Exec:0.1095s Template:0.1355s )|DB:13 queries 0 writes| Cache:2 gets,0 writes|UseMem:415 kb|LoadFile:20|CallFun:63,1370 " /> 中文字幕无码A片久久,午夜福到在线4国产,久久这里只精品国产99re66

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

獲取php頁面執(zhí)行時間,數(shù)據(jù)庫讀寫次數(shù),函數(shù)調(diào)用次數(shù)等(THINKphp)

THINKphp里面有調(diào)試運行狀態(tài)的效果:

Process:0.2463s (Load:0.0003s Init:0.0010s Exec:0.1095s Template:0.1355s )|DB:13 queries 0 writes| Cache:2 gets,0 writes|UseMem:415 kb|LoadFile:20|CallFun:63,1370

代表的含義:

運行信息: 整體執(zhí)行時間0.2463s ( 加載:0.0003s 初始化:0.0010s 執(zhí)行:0.1095s 模板:0.1355s ) | 數(shù)據(jù)庫 :13次讀操作 0次寫操作 | 緩存:2次讀取,0次寫入 | 使用內(nèi)存:415 kb | 加載文件:20 | 函數(shù)調(diào)用:63(自定義),1370(內(nèi)置)

下面來分析一下這些數(shù)據(jù)是怎么獲取到的?

php獲取頁面執(zhí)行時間:
復(fù)制代碼 代碼如下:
/**
* 得到當(dāng)前時間
*/
function getMicrotime() {

list ($usec, $sec) = explode(" ", microtime());
return ((float) $usec + (float) $sec);
}


使用:上面的方法可以獲取當(dāng)前時間,計算頁面執(zhí)行時間可以在程序開頭和結(jié)尾出分別執(zhí)行該方法,最后時間差就是頁面執(zhí)行的時間,原理很簡單。

獲取數(shù)據(jù)庫讀寫次數(shù)

在數(shù)據(jù)庫插入和讀取的時候設(shè)置一個全局變量,每次執(zhí)行成功一次$i++一次, ,這是tp里面db類的方法,而N的方法是:自動累計的一個方法。

同理緩存也是這樣計算出來的

內(nèi)存的開銷
memory_get_usage可以獲取當(dāng)前內(nèi)存的消耗量,可以在程序開始和結(jié)尾分別調(diào)用,差值就是內(nèi)存的開銷

加載文件的數(shù)量
get_included_files:Gets the names of all files that have been included using include, include_once, require or require_once.

也就是可以獲取到所有的include,require的文件數(shù),返回引入文件的數(shù)組:

官網(wǎng)例子":

復(fù)制代碼 代碼如下:
<?php
// This file is abc.php

include 'test1.php';
include_once 'test2.php';
require 'test3.php';
require_once 'test4.php';

$included_files = get_included_files();

foreach ($included_files as $filename) {
echo "$filenamen";
}
?>


返回的結(jié)果是:

abc.php
test1.php
test2.php
test3.php
test4.php

函數(shù)調(diào)用方法
第一個看這個,感覺是在每個方法里面調(diào)用時自動+1.但是感覺不大可能,貌似這個每個方法里寫不靠譜,這群里討論半天,最后發(fā)現(xiàn)php的一個函數(shù):

get_defined_functions返回引入php文件的所有方法的array格式,包括自定義的,內(nèi)置的。

引入官網(wǎng)的一個例子:

復(fù)制代碼 代碼如下:
<?php
function myrow($id, $data)
{
return "<tr><th>$id</th><td>$data</td></tr>n";
}
$arr = get_defined_functions();
print_r($arr);
?>


結(jié)果是:

復(fù)制代碼 代碼如下:
Array
(
[internal] => Array
(
[0] => zend_version
[1] => func_num_args
[2] => func_get_arg
[3] => func_get_args
[4] => strlen
[5] => strcmp
[6] => strncmp
...
[750] => bcscale
[751] => bccomp
)

[user] => Array
(
[0] => myrow
)
)


user為自定義方法,internal為內(nèi)置方法數(shù)組。

引申:

get_defined_constants 獲取定義所有常量的數(shù)組
get_defined_functions 獲取定義所有函數(shù)的數(shù)組
get_defined_vars 獲取定義所有變量的數(shù)組
get_declared_classes 返回已經(jīng)定義的類的數(shù)組

php技術(shù)獲取php頁面執(zhí)行時間,數(shù)據(jù)庫讀寫次數(shù),函數(shù)調(diào)用次數(shù)等(THINKphp),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲狠狠97婷婷综合久久久久 | 18岁末年禁止观看免费1000个 | 国产精品亚洲AV色欲在线观看 | 色戒2小时38分在线观看 | 日产国产欧美韩国在线 | 国产偷抇久久精品A片蜜臀AV | 色欲AV精品人妻一区二区三区 | 精品无码三级在线观看视频 | 天天躁人人躁人人躁狂躁 | 久久婷婷色香五月综合激情 | 免费色片播放器 | 3a丝袜论坛 | 国产欧美国产综合第一区 | 欧美一级久久久久久久大 | 日本无码色哟哟婷婷最新网站 | 国产亚洲人成在线视频 | 亚洲精品第五页中文字幕 | 亚州三级视频 | 国产成人综合在线观看网站 | 国产成人国产在线观看入口 | 国产一区2区 | 97人妻丰满熟妇AV无码 | 亚洲精品视频免费在线观看 | 国产免费人成在线看视频 | 强奷乱码欧妇女中文字幕熟女 | 蜜桃成熟时33D在线嘟嘟网 | 日本久久久久亚洲中字幕 | 99热这里只有精品9 99热这里只有精品88 | 一区二区视频在线观看高清视频在线 | 岛国片在线免费观看 | 国产黄A片在线观看永久免费麻豆 | 亚洲精品午夜aaa级久久久久 | 亚洲欧美免费无码专区 | 九九99热久久精品在线6 | 三男强一女90分钟在线观看 | 伦理片飘花免费影院 | 偷拍亚洲制服另类无码专区 | 在线看片av以及毛片 | 女性性纵欲派对 | 毛片网站在线观看 | ass女人下部欣赏 |