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 " /> 小明台湾www永久视频,一级片视频免费观看,免费看国产精品久久久久

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

獲取php頁面執行時間,數據庫讀寫次數,函數調用次數等(THINKphp)

THINKphp里面有調試運行狀態的效果:

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

代表的含義:

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

下面來分析一下這些數據是怎么獲取到的?

php獲取頁面執行時間:
復制代碼 代碼如下:
/**
* 得到當前時間
*/
function getMicrotime() {

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


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

獲取數據庫讀寫次數

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

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

內存的開銷
memory_get_usage可以獲取當前內存的消耗量,可以在程序開始和結尾分別調用,差值就是內存的開銷

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

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

官網例子":

復制代碼 代碼如下:
<?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";
}
?>


返回的結果是:

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

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

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

引入官網的一個例子:

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


結果是:

復制代碼 代碼如下:
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為內置方法數組。

引申:

get_defined_constants 獲取定義所有常量的數組
get_defined_functions 獲取定義所有函數的數組
get_defined_vars 獲取定義所有變量的數組
get_declared_classes 返回已經定義的類的數組

php技術獲取php頁面執行時間,數據庫讀寫次數,函數調用次數等(THINKphp),轉載需保留來源!

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

主站蜘蛛池模板: 一区二区三区免费视频播放器 | 91在线播放网站 | 色婷婷综合久久久中文字幕 | 国语自产精品视频在线第 | 欧美人与禽zoz0性伦交免费看 | 狠狠色噜噜狠狠狠狠米奇7777 | 国产精品深夜福利免费观看 | 91麻豆影视| 天天色天天综合 | 麻豆国产视频 | 国产成人亚洲精品 | 日本免费一区二区三区看片 | 久久综合图片 | a级国产乱理论片在线观看 a级国产乱理论片在线观看看 | 巨大欧美黑人xxxxbbbb | 在线观看免费视频网站色 | 99久久精品费精品国产 | 日本伊人精品一区二区三区 | 精品日本亚洲一区二区三区 | 国产精品欧美一区二区在线看 | 在线观看国产精美视频 | 亚洲一区二区综合 | 99视频有精品视频免费观看 | 国产91久久久久久久免费 | 国产高清国产专区国产精品 | 97爱sese| 色哟哟在线免费观看 | 在线免费午夜视频 | 在线视频一二三区 | 黄色网战在线观看 | 999re6热在线精品视频思思 | 精品网址| 国产91第一页 | 最新日本免费一区二区三区中文 | 唯美久草| 欧美成人第一页 | 91久久夜色精品国产网站 | 国产对白在线播放九色 | 成人免费观看视频 | 韩国一级爽快片淫片高清 | 不卡一区二区三区四区 |